Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Servers
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 20-09-2006
RaulChemical RaulChemical is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 59
Poder: 21
RaulChemical Va por buen camino
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:

Código Delphi [-]

Procedure CrearYConectarExcel(Fichero: String;
                              Var Lcid : Integer;
                              Var EXAplication : TExcelApplication;
                              Var EXWorkBook : TExcelWorkbook;
                              Var EXWorkSheet : TExcelWorksheet);
var
  wbk : _Workbook;
begin
  Lcid := LOCALE_USER_DEFAULT;
  EXAplication := TExcelApplication.Create(Application);
  EXWorkBook := TExcelWorkbook.Create(Application);
  EXWorkSheet := TExcelWorksheet.Create(EXWorkBook);
  wbk := EXAplication.Workbooks.Add(EmptyParam,LCID);
  EXWorkBook.ConnectTo(EXAplication.Workbooks.Open(fichero, EmptyParam, EmptyParam,
                                                   EmptyParam, EmptyParam, EmptyParam,
                                                   EmptyParam, EmptyParam, EmptyParam,
                                                   EmptyParam, EmptyParam, EmptyParam,
                                                   EmptyParam, EmptyParam, EmptyParam,
                                                   Lcid));
  EXWorkSheet.ConnectTo(EXWorkBook.ActiveSheet as ExcelWorkSheet);
  EXAplication.DisplayAlerts[Lcid];
end;

Y para el cierre y la liberacion hago esto:

Código Delphi [-]
Procedure CerrarYLiberarExcel(Fichero: String;
                              Var Lcid : Integer;
                              Var EXAplication : TExcelApplication;
                              Var EXWorkBook : TExcelWorkbook;
                              Var EXWorkSheet : TExcelWorksheet);
begin
  EXAplication.DisplayAlerts[LCID]:=False;
  EXWorkBook.Close(True,Fichero,emptyParam,LCID);
  EXWorkSheet.Disconnect;
  EXWorkBook.Disconnect;
  EXAplication.Quit;
  EXAplication.Disconnect;
  FreeAndNil(EXWorkSheet);
  FreeAndNil(EXWorkBook);
  FreeAndNil(EXAplication);
end;

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.
__________________
ash nazg durbatulûk
ash nazg gimbatul
ash nazg thrakatulûk
agh burzum-ishi krimpatul
Responder Con Cita
  #2  
Antiguo 21-09-2006
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
Inmediatamente después de crear la instancia de Excel, especifica el modo de conexión:

Código Delphi [-]
EXAplication := TExcelApplication.Create(Application);
EXAplication.ConnectKind := ckNewInstance;

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
Responder Con Cita
  #3  
Antiguo 21-09-2006
RaulChemical RaulChemical is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 59
Poder: 21
RaulChemical Va por buen camino
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.
__________________
ash nazg durbatulûk
ash nazg gimbatul
ash nazg thrakatulûk
agh burzum-ishi krimpatul
Responder Con Cita
  #4  
Antiguo 21-02-2008
grotero76 grotero76 is offline
Miembro
 
Registrado: feb 2007
Posts: 32
Poder: 0
grotero76 Va por buen camino
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.
Responder Con Cita
  #5  
Antiguo 21-02-2008
RaulChemical RaulChemical is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 59
Poder: 21
RaulChemical Va por buen camino
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).

Código Delphi [-]
function KillTask(FileName:String):integer;
var
  ContinueLoop:BOOL;
  FSnapshotHandle:THandle;
  FProcessEntry32:TProcessEntry32;
const
  PROCESS_TERMINATE=$0001;
begin
Result:=0;
  FSnapshotHandle:=CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
  FProcessEntry32.dwSize:=Sizeof(FProcessEntry32);
  ContinueLoop:=Process32First(FSnapshotHandle,FProcessEntry32);
  while integer(ContinueLoop)<>0 do
  begin
    if ((UpperCase(ExtractFileName(FProcessEntry32.szExeFile))=UpperCase(FileName)) or
       (UpperCase(FProcessEntry32.szExeFile)=UpperCase(FileName))) then
      Result:=Integer(TerminateProcess(OpenProcess(PROCESS_TERMINATE,BOOL(0),
                                       FProcessEntry32.th32ProcessID),0));
    ContinueLoop:=Process32Next(FSnapshotHandle,FProcessEntry32);
  end;
  CloseHandle(FSnapshotHandle);
end;

Espero que te sirva la función o parte de ella.

Suerte.
__________________
ash nazg durbatulûk
ash nazg gimbatul
ash nazg thrakatulûk
agh burzum-ishi krimpatul
Responder Con Cita
  #6  
Antiguo 21-02-2008
grotero76 grotero76 is offline
Miembro
 
Registrado: feb 2007
Posts: 32
Poder: 0
grotero76 Va por buen camino
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;
var H:word;
begin
     H := CreateFile(PChar(FileName), GENERIC_READ, 0, nil, OPEN_EXISTING, 0, 0);
     Result := (H >= 65535);
     CloseHandle(H);
end;
de esta manera controlo que un mismo fichero no intenten
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
       KillTask(FileName)
¿Hay algo que se me escape que pueda estar haciendo mal?

Muchas gracias de nuevo.

Un saludo.
Responder Con Cita
  #7  
Antiguo 21-02-2008
RaulChemical RaulChemical is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 59
Poder: 21
RaulChemical Va por buen camino
Yo llamo al killtask así y funciona:

Código Delphi [-]
KillTask('EXCEL.EXE');

Prueba así a ver....
__________________
ash nazg durbatulûk
ash nazg gimbatul
ash nazg thrakatulûk
agh burzum-ishi krimpatul
Responder Con Cita
  #8  
Antiguo 21-02-2008
grotero76 grotero76 is offline
Miembro
 
Registrado: feb 2007
Posts: 32
Poder: 0
grotero76 Va por buen camino
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.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Cerrar conexión al cerrar formulario arantzal Conexión con bases de datos 5 09-08-2006 12:43:52
cerrar objeto de excel mak8888 Servers 4 11-02-2006 00:11:04
Cerrar Excel EstebanWeb Servers 5 20-12-2004 10:05:02
Cerrar excel desde una aplicaion delphi VolaRe Servers 0 02-05-2004 20:41:20
al cerrar un libro se me cierra el Excel! haron Servers 0 30-05-2003 11:07:26


La franja horaria es GMT +2. Ahora son las 01:50:16.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi