![]() |
No cerrar Excel
Hola Foro!!!!
Tengo cierto problemilla con mi carga desde Excel. Os cuento: Realizo una carga desde un fichero excel y cuando llego al final del fichero cierro Excel. Hasta aqui, no hay ningun problema, el caso es que si el usuario ya tenia abierto el excel antes, al finalizar mi carga, cierro mi fichero y el que ya tenia abierto el usuario. Uso ExcelXP. Os detallo como hago la creacion, apertura, cierre y liberacion del excel: Para la creacion y apertura llamo al siguiente procedimiento:
Y para el cierre y la liberacion hago esto:
El problema que tengo es que no se como hacer para que al CerrarYLiberarExcel(...) no se como hacer para que no se cierre el/los otro/s posible/s exceles abiertos. He probado de momento quitando el EXAplication.Quit y el EXAplication.Disconect, pero al liberar el objeto, me cierra la aplicacion y si no libero, me suelta un RunTimeError de los que te suelta Excel. ¿Realmente se puede hacer que se cierre el excel que yo he abierto y que continue ejecutandose el otro excel? Estoy pensando continuar por otra via, que es comprobar al principio de la ejecucion si excel está corriendo. En caso de que esté, soltarle un mensaje al usuario diciendole que Excel ya está en ejecucion. ¿Sabeis alguno como saber encontrar una tarea en ejecucion (en concreto el excel) dentro del administrador de tareas?. Cualquiera de las opciones me es viable, tanto la "bonita" (solo cerrar mi fichero y que Excel continue en ejecucion) como la "drastica" (evitar mi porceso de carga si Excel esta en ejecucion). Muchas gracias a todos. Raul. |
Inmediatamente después de crear la instancia de Excel, especifica el modo de conexión:
Esto hará que se abra un nuevo proceso de Excel. Incluso verás un segundo botón en la barra de tareas. Cuando desconectes, sólo se cerrará el segundo proceso. // Saludos |
Muchas gracias!!!!
En vez de eso, puse un buclecillo que hasta que no detectase que se habia cerrado el excel, no iniciaba el proceso de carga, pero ya lo he modificado y mola xq con lo que tu me has dicho se permiten "n" procesos de excel y no se cierra ninguno al finalizar. Muchas gracias de nuevo!!! Un saludo. Raul. |
Buenas a todos,
Necesito saber si EXCEL se está ejecutando antes lanzar la instancia del mismo que crea mi aplicación, ¿Es posible saber si EXCEL está en ejecución dentro del administrador de tareas?. Muchas gracias. Un saludo. |
Matamos el excel
Buenas....
En algunos otros puntos de la aplicación, a petición del cliente, matamos el excel. Para matarlo, llamamos a esta función que encontramos en el TrucoMania (creo).
Espero que te sirva la función o parte de ella. Suerte. |
Muchas gracias por tu rápida respuesta,
el caso es que la función que me has pasado no consigue matarme el proceso de Excel. He conseguido detectar si un fichero en cuestión se está ejecutando con la siguiente función: Código:
function EstaEjecutandose (FileName:string): boolean; abrirlo dos veces, pero lo que quería era poder matar el proceso que se está ejecutando y a continuación abrir una nueva instancia. Hago una llamada a la función KillTask pero no hace nada, no se si la estoy utilizando bien, simplemente hago lo siguiente: Código:
if EstaEjecutandose(FileName) then Muchas gracias de nuevo. Un saludo. |
|
Ok, funciona, como el parámetro de la función KillTask era Filename pensé que había que pasarle el nombre del fichero en lugar del proceso, me había echo un lio.
Muchas gracias. |
La franja horaria es GMT +2. Ahora son las 12:56:58. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi