![]() |
Como saber si un fichero está abierto
Buenas!
Tengo que mover de directorio una serie de ficheros (algunos son word, un fdb, varios ini's...) pero antes de hacerlo, necesito saber si alguno de esos ficheros están abiertos por otra aplicación antes de moverlos de directorio. Sabéis si hay alguna función que devuelva el estado del fichero? Muchas gracias. |
|
Mi problema no es saber si un programa está en ejecución, es saber si un fichero (.doc, .fdb, .ini....) está abierto.
El directorio que quiero mover es el directorio donde se encuentra la base de datos de otra aplicación nuestra. Si la base de datos está abierta, ya sea por la aplicación o por el IBExpert, no debo intentar moverla, al igual que el resto de ficheros que hay en el mismo directorio. |
Buscando un poco en la internet, se encuentran algunas funciones interesantes
http://mc-computing.com/languages/De...lphiFileIO.htm También algo sobre el manejo de las excepciones: http://zarza.fis.usal.es/~fgarcia/do...bajos/S2T5.pdf Quizá te sirvan mientras ;) |
Hola,
En realidad a mí me parece que no hay forma de saber si un archivo está abierto o qué, a no ser que la aplicación que lo abra lo haga "de forma exclusiva". En este caso tal vez uno podría comprobar si el archivo, efectivamente, fue abierto de esa forma, dicho mal y pronto. Pero, si la aplicación que abre un archivo (y es lo normal) no lo abre de forma exclusiva, ya digo, puedo estar equivocado, pero, ¿cómo podría averiguarse que el archivo en cuestión está abierto? Te pondré un ejemplo. Una aplicación de Delphi cuenta con un "TMemo" en el que carga el contenido de un archivo. La aplicación lee el archivo, y pone su contenido en el "TMemo". Y ahí se acaba todo. El archivo puede incluso eliminarse a continuación, que, el contenido del mismo seguirá en el "TMemo". Si otra aplicación quiere saber si la mía abrió el archivo de marras, ¿cómo iba a hacerlo? |
Yo pensé en los atributos del documento en ese momento... como cuando abres dos veces un archivo de excell te dice en "modo de solo lectura", quizá el se refiera a eso...
|
Hola,
No sabía de esto último que dices Felipe. Aunque, probablemente, Excel abra el archivo "de forma exclusiva", y así luego puede averiguar si el archivo está abierto de esa forma: aunque sea por la propia aplicación, de modo que lo abra como "sólo lectura". Lo cierto es que tampoco te creas que estoy muy puesto en este asunto. Pero lo que hace Excel tiene su lógica, para evitar ediciones en un archivo que ya está abierto "de forma exclusiva", por el mismo Excel o por otra aplicacion. Pero, esto lo hace Excel... mas no todas las aplicaciones lo hacen. Me parece que es al contrario: lo normal es abrir archivos no de forma exclusiva, sino leer su contenido y ponerlo a disposición del usuario, pero, dejar el archivo donde estaba y como estaba. Pero, creo que me estoy yendo por las ramas. :D |
Bueno, yo también me he enfrentado a ese problema y la solución que le di es lo que dice dec, abrir, ademas, de forma exclusiva, guardar el manejador del fichero para luego "liberarlo" al cerrar. De esa manera detectaba que el fichero no podía ser "tocado".
Saludos. |
Cita:
Saludos :) |
Hola,
El asunto está en determinar qué entendemos por un archivo "en uso". Si yo desde Delphi abro para leerlo un archivo de texto y lo cargo en un "TMemo", ese archivo realmente no está "en uso". Simplemente lo abrí, lo leí y ya está. Para que pueda considerarse que un archivo está usándose, hasta donde yo llego, una aplicación ha de abrir el archivo en cuestión "en modo exclusivo", tal como apunta también el compañero Escafandra. En este caso Windows no dejaría mover el archivo abierto "en exclusiva" por una aplicación. Al menos hasta donde yo llego. ;) |
Claro Dec... de acá en adelante depende es del modo en como "usen" esos archivos los otros programas...
|
Cita:
Esto es posible porque se ha utilizado FILE_SHARE_DELETE al momento de abrir el archivo... que sucede? al ser borrado o eliminado el archivo los datos siguen allí intactos lo único que cambia son las entradas de ROOT o de MFT en el sistema de archivos. Cita:
El S.O. bloquea por alguna razón lógica un archivo, y es necesario forzar el acceso al mismo por cualquier motivo... para ello la mejor herramienta que puedo nombrar de la telaraña es "Unlocker" de Cedrick Collomb. Por qué es tan eficaz dicha herramienta? sin ánimos de quitar el encanto y la excelente calidad del trabajo de Collomb, comentaré que dicha herramienta funciona basada en dos APIs (ObReferenceObjectByHandle & ObfDereferenceObject) las cuales a nivel de núcleo (S.O.) desbloquean los archivos a voluntad y de la mejor forma posible. Lo anteriormente dicho es solo con fines informativos pues no tenemos el permiso del autor para crear una librería basada en su trabajo, pero si podemos apoyarnos en otras APIs que nos facilitaran el trabajo; adjunto un ejemplo que dará la idea de lo que digo:
La anterior aplicación de consola muestra todos los archivos abiertos y los programas que han abierto a dichos archivos y puede adaptarse para otros fines :cool:. Es claro que no tiene el “poder” de Unlocker, pero es un precedente para aplicaciones a nivel de usuario que requieran de dichas funcionalidades. Saludos |
Cita:
|
perdon q me meta... pero el wmp no guarda el archivo en la biblioteca sino lo q referencia es el path donde se aloja el archivo y lo usa cuando esta reproduciendo... de hecho, intenta borrar o mover un archivo mientras lo esta reproduciendo y no te va a dejar.... aunque si los archivos estan cargados en tu lista, vos podes borrarlos o moverlos, solo perdes la referencia en tu wmp o cualquier otro reproductor, puesto q el archivo todavia no fue tocado... no aporto mas porque esta claro lo q dice dec, el archivo puede ser leido sin mantenerlo abierto en forma exclusiva, aunque diferente es q mantengas la aplicacion abierta con el uso del archivo... hay q separar esos 2 ptos, pero de todos modos, no es posible saber si un archivo esta siendo abierto, salvo q intentes modificarle algo y salte el bendito cartel alertando q es una operacion invalida(como borrar o mover un archivo mientras esta siendo reproducido en el wmp ;)). saludosssssss
|
La franja horaria es GMT +2. Ahora son las 13:11:36. |
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