- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 11:48 AM
Estoy teniendo un problema con BP, cuando lo corro solo, el proceso se detiene cuando quiere trabajar con un excel, apareciendo el siguiente error :
ERROR: Internal : Could not execute code stage because exception thrown by code stage: El valor no puede ser nulo. Nombre del parámetro: s |
y cuando lo corro manualmente lo hace bien.
Alguien sabe que puede ser?
Saludos!
------------------------------
Sofia Danieli
------------------------------
Answered! Go to Answer.
Helpful Answers
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 05:30 PM
Perdonarme la insistencia con el tema del código, pero creo que es la solución mas elegante, ya que estar con un sistema de reintentos poco "solido" es jugarsela mucho en un entorno productivo. Para que te sea mas facil, te paso un fragmento de código rapido:
Primeramente te vas a tener que instalar el componte de conexiónes que proporciona Microsoft en su página oficial: https://www.microsoft.com/es-es/download/confirmation.aspx?id=13255
Seguidamente, en un objeto nuevo que crees, tienes que:
- añadir la referencia a la DLL System.Data.OleDb.dll
- añadir el espacio de nombres System.Data.OleDb (el de la libreria)
- despues añade en un fragmento de codigo lo siguiente:
Como valores de entrada; el fichero Excel y el nombre de la hoja
Y el codigo es el siguiente
OleDbConnection connection = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + strExcelFile + ";");
connection.Open();
OleDbCommand command = new OleDbCommand();
command.Connection = connection;
command.CommandText = "SELECT * FROM " + strNombreHoja;
DataTable dt = new DataTable();
dt.Load(command.ExecuteReader());
Result = dt;
Esto te devuelve una collection que tienes que almacenar como valor de salida. Creala conforme venga tu Excel.
Un saludo,
------------------------------
Pablo Sarabia
Programmer
Altamira AM
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 12:23 PM
TIenes un poco mas de antecedentes?, que objeto/accion/stage esta tirando ese error?
Saludos,
------------------------------
Conrado Meli
Managing Partner
Primus IA
America/Santiago
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 01:38 PM
Generalmente, los fallos de este tipo pueden venir por falta de algun "sleep" que de tiempo a la aplicación de Excel a cargarse.
De todas formas, dos preguntas:
1. El "debug" y la ejecución de la control Room las haces en la misma máquina? De no ser así, revisa que las librerías que usas estén bien en la máquina donde ejecutas en "automático"
2. ¿La conexión al Excel la haces en modo visual? o ¿con alguna clase por código?
Un saludo
------------------------------
Pablo Sarabia
Programmer
Altamira AM
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 01:42 PM
Cuál es la versión de Blue Prism? Con 6.4.2 o anterior, el portapapeles podría ser la causa del error.
Aquí hay un artículo sobre este mensaje de error:
https://portal.blueprism.com/customer-support/support-center#/path/Automation-Design/Application-Integration/EXCEL/1323720772/Why-do-I-get-Value-cannot-be-null-Parameter-name-s-error-when-using-the-MS...
------------------------------
Patrick Aucoin
Senior Product Consultant
Blue Prism
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 02:12 PM
------------------------------
Sofia Danieli
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 02:27 PM
------------------------------
Sofia Danieli
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 03:00 PM
¿Te aseguras de que abra visualmente el excel y no lo deje en segundo plano o algo similar?
Mira también que no haya lineas vacías, cuando se borran datos en Excel hay veces que se quedan con datos nulos que luego dan problemas. Por hacer la prueba, te recomiendo que "elimines" el resto de lineas y columnas que no tengan datos. Puedes seleccionar la primera linea vacía haciendo clic en el numero, y con la combinación de teclas [Control] + [Shift] + [Tecla de dirección abajo] seleccionarlas todas, después, clic derecho y eliminar. De la misma manera repite esta acción con las columnas.
De todas formas, si lo que quieres es transformar los datos del Excel a una colección, puedes probar a utilizar OLEDB VBO y hacer las consultas como si se tratara de un origen de datos de SQL. No sería demasiado código.
Un saludo,
------------------------------
Pablo Sarabia
Programmer
Altamira AM
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 03:25 PM
Si abrís el objeto de Excel VBO en el Object Studio te muestra que tiene errores?
------------------------------
Aníbal Facundo Urrestarazu
Lead Developer
Ctrl365 - Argentina
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 04:40 PM
Hay uno que lo solvento con un sistema de reintentos sobre la actividad. Poniendo un bloque y un recover, un sleep y posteriormente un decision(Reintentos<Contador). De aquí conectaba a un Exception o un Calculate (Contador+1) para que lo reintentase las veces que considerase que era oportuno reintentarlo y de ahí al resume y de nuevo a la actividad.
Porque en principio aun dejando las variables tanto del workbook name, como el handle y el WorkSheet name vacíos no debería devolverte ese error (en principio es la forma en la que funciona el método fast del get worksheet as collection).
Mi versión es anterior a la tuya 6.5.0.12573 y no me ha sucedido en mi propia máquina. En otro recurso no te puedo decir.
------------------------------
Jesús Miguel Bravo Díaz
RPA Developer
Atento
Europe/Madrid
------------------------------
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
04-11-20 05:30 PM
Perdonarme la insistencia con el tema del código, pero creo que es la solución mas elegante, ya que estar con un sistema de reintentos poco "solido" es jugarsela mucho en un entorno productivo. Para que te sea mas facil, te paso un fragmento de código rapido:
Primeramente te vas a tener que instalar el componte de conexiónes que proporciona Microsoft en su página oficial: https://www.microsoft.com/es-es/download/confirmation.aspx?id=13255
Seguidamente, en un objeto nuevo que crees, tienes que:
- añadir la referencia a la DLL System.Data.OleDb.dll
- añadir el espacio de nombres System.Data.OleDb (el de la libreria)
- despues añade en un fragmento de codigo lo siguiente:
Como valores de entrada; el fichero Excel y el nombre de la hoja
Y el codigo es el siguiente
OleDbConnection connection = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + strExcelFile + ";");
connection.Open();
OleDbCommand command = new OleDbCommand();
command.Connection = connection;
command.CommandText = "SELECT * FROM " + strNombreHoja;
DataTable dt = new DataTable();
dt.Load(command.ExecuteReader());
Result = dt;
Esto te devuelve una collection que tienes que almacenar como valor de salida. Creala conforme venga tu Excel.
Un saludo,
------------------------------
Pablo Sarabia
Programmer
Altamira AM
------------------------------