Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Verificar si una imagen existe (https://www.clubdelphi.com/foros/showthread.php?t=34325)

mcarazas 05-08-2006 00:05:27

Verificar si una imagen existe
 
Hola Amigos del foro:

Tengo un problema, estoy cargando imágenes con TImage pero esto lo hago dinámicamente con una cadena de la base de datos lo que pasa es que no puedo controlar si una imagen existe, cuando el sistema no encuentra el archivo me manda una excepción como puedo controlar si el archivo existe o no este es el código que estoy utilizando

Código Delphi [-]

procedure TformInventarios.proCargarImagenes(Im: TImage; ruta: String; imagen: String);
var
ImgExt: String;
begin


    Im.Picture.LoadFromFile(ruta + imagen + '.JPG');
    Im.Stretch:= True;


end;

Espero puedan ayudarme, gracias.

seoane 05-08-2006 00:12:49

Código Delphi [-]

procedure TformInventarios.proCargarImagenes(Im: TImage; ruta: String; imagen: String);
var
ImgExt: String;
begin
  Im.Stretch:= True;
  try
    Im.Picture.LoadFromFile(ruta + imagen + '.JPG');    
  except
     ShowMessage('No puedo cargar la imagen');
  end;
end;

vtdeleon 05-08-2006 00:16:28

Saludos

También con la función FileExists
Código Delphi [-]
If FileExists(ruta+imagen+'.JPG') then
//rutinas
else
//rutanas

mcarazas 05-08-2006 00:36:34

Agradecimiento
 
Gracias por responder me ayudaron a resolver el problema que tenia.

dec 05-08-2006 14:48:56

Hola,

Cita:

Empezado por Seoane
Código Delphi [-]
procedure TformInventarios.proCargarImagenes(Im: TImage; ruta: String; imagen: String);
var
ImgExt: String;
begin
  Im.Stretch:= True;
  try
    Im.Picture.LoadFromFile(ruta + imagen + '.JPG');
  except
     ShowMessage('No puedo cargar la imagen');
  end;
end;

Hum... ;)

Cita:

Empezado por Troi
Código Delphi [-]
If FileExists(ruta+imagen+'.JPG') then
  //rutinas
else
  //rutanas

Hum... ;)

¿Y qué pasa luego? ¿Os creéis que podéis iros de rositas luego de dejar ese código fuente ahí, como el que no quiere la cosa? ¿O qué? ¿Con cuál me quedo? ¿Hago uso de las excepciones? ¿Utilizo la función "FileExists"? ¿Hago lo que quiera? ¿Sería más "lógico" (respeto tengo a esta palabra) elegir el camino de la excepción? ¿Acaso no es la función "FileExits" una reliquia de la época aquélla en que no se conocían las excepciones?

Si no es por discutir, y menos con la que está cayendo (en Oriente Medio y acaso en otros lugares),... si no es que quiera armar aquí un "flame" ni nada de eso... se trata simplemente de que opinéis, si queréis, claro. :eek: :eek: :D :D

seoane 05-08-2006 15:12:17

Si es cuestión de defender una opción, yo sigo optando por las excepciones. No porque no sea perfectamente valida FileExists, sino porque esta solo comprueba que el archivo existe pero no que sea una imagen valida. Si resulta que el archivo en cuestión no es una imagen o esta corrupto no enfrentaríamos a una excepción no controlada. Así que de usar FileExists también seria necesario usar try ... except y por eso de economizar código mejor usar excepciones directamente y nos ahorramos un paso.

¿que te parece ahora dec? :D

vtdeleon 05-08-2006 15:25:18

Con esos argumentos, creo que me ganó:(

Saludos

dec 05-08-2006 15:27:30

Hola,

Cita:

Empezado por Troi
Con esos argumentos, creo que me ganó:(

Na,... no creo que se trate de ganar a nadie. ;)

Cita:

Empezado por Seoane
¿que te parece ahora dec? :D

Que a mí también me convencieron tus argumentos Seoane. ¿Habrá más aún? :D :D :D

roman 05-08-2006 19:29:43

Cita:

Empezado por dec
¿Habrá más aún? :D :D :D

Esto es trampa :p En este caso específico, por las razones que menciona seoane, estoy de acuerdo. Pero en general no me gusta usar excepciones a diestra y siniestra cuando hay formas de preveer el posible error. Ya anteriormente hemos discutido esto y me quedo con lo que indica la misma ayuda de Delphi.

// Saludos

Lepe 05-08-2006 22:44:39

Supongo que "preveer hasta cierto punto", porque si tenemos que comprobar que el fichero:
- existe
- es un jpg
- no está corrupto

Hecho mediante try.. except, try finallys y demás... me parece demaisado.

En este caso, teniendo una ventana de Inventario por detrás y muy posiblemente una base de datos, yo simplemente haría un Try ... except, y dentro del except pondría en un estado estable las variables que puedan dar efectos colaterales, despues, lanzaría mi propia excepción.

Con código:
Código Delphi [-]
procedure TformInventarios.proCargarImagenes(Im: TImage; ruta: String; imagen: String);
var
ImgExt: String;
begin
  Im.Stretch:= True;
  try
    Im.Picture.LoadFromFile(ruta + imagen + '.JPG');    
  except
     if im <> nil then // chequeamos no nos salte otra excepcion aqui :D :D
       im.picture.Clear;
      ruta := EmptyStr;
      imagen := EmptyStr;
      raise Exception.CreateFmt(' la imagen %s%s no se ha podido cargar',[imagen, ruta]);
  end;
end;

Saludos

courtois 06-08-2006 07:28:00

y que mas?, no se cargó la imagen? por que? o que? asi nadamas sin explicación? si digo que no esta el jpg no le ayudo en algo a mi usuario?
y si digo que si está pero está corrupto no le ayudo tampoco?

dec 06-08-2006 07:48:36

Hola,

Bueno. Supongo que dentro del bloque "try...except" puedes "mirar" por distintos tipos de excepciones (que creo que por ahí van los tiros, que vamos al todo o nada, cuando existen distintos tipos de excepciones, e incluso los que nosotros podemos crear por nuestra cuenta). De ese modo podrías indicar al usuario más o menos por dónde van los tiros, qué puede estar fallando. ¿No? :)

seoane 06-08-2006 12:24:51

Cita:

Empezado por courtois
y que mas?, no se cargó la imagen? por que? o que? asi nadamas sin explicación? si digo que no esta el jpg no le ayudo en algo a mi usuario?
y si digo que si está pero está corrupto no le ayudo tampoco?

Si lo que necesitas es información que te parece esto:
Código Delphi [-]
procedure CargarImagen(Imagen: TImage; Filename: String);
begin
  try
    Imagen.Picture.LoadFromFile(Filename);
  except
    on EInvalidGraphic do
    begin
      ShowMessage('No reconozco este tipo de grafico');
    end;
    on EFOpenError do
    begin
      ShowMessage('No puedo abrir archivo: ' + SysErrorMessage(GetLastError));
    end;
    on EOutOfResources do
    begin
      ShowMessage('No hay mas recursos disponibles: ' + SysErrorMessage(GetLastError));
    end;
    on E: EOSError do
    begin
      ShowMessage('Error del sistema: ' + SysErrorMessage(E.ErrorCode));
    end;
    on EReadError do
    begin
      ShowMessage('Error de lectura, puede que el archivo este corrupto');
    end;
  else
    begin
      ShowMessage('Error desconocido');
    end;
  end;
end;

Los mensajes podrían ser mas explícitos pero el SysErrorMessage nos dará mas información sobre lo que paso (si el archivo no existe, si no tenemos permiso para leerlo, etc)

Lepe 06-08-2006 15:49:41

ok, pero eso es para cargar una imagen... si despues necesitamos cargar un fichero de texto, hay que hacer algo parecido (las excepciones cambian), si vamos a crear en memoria una lista de objetos... pongamos 10, pues tambien hay que crear una rutina .... ¿ves por donde voy?

Cada operación a realizar puede involucrar fallos, intentar evitarlos todos te llevaría 4 veces más, en tiempo y presupuesto, ¿tu cliente estará de acuerdo?, en cuanto al dinero seguro que no. No queda más remedio que controlar "superficialmente" ese tipo de fallos.

El usuario coge un archivo jpg, le cambia la extension a bmp (porque nuestro programa solo damos soporte a bmp) y .... ¿para eso le das un mensaje específico de ese fallo?... por dios, ese tipo sabe lo que hace; si no lo sabe y le da el error, pues le decimos que tiene que usar el paint [...] pero de ahí a controlar todos los errores que pueden dar... parece demasiado.

El cliente te contrata para hacer un programa que "haga lo que él quiere" pero no pide un control exhasutivo de errores, es más.. decirle que se ha producido un error de "entrada / salida" le va a ayudar muy poco, creemé. Por otra parte los usuarios quieren programas sin tecnicismos, de lo contrario haces que parezcan ignorantes o tontos (aunque lo sean :D).

A veces, viendo los conocimientos que tiene nuestro cliente de informática damos más o menos información... pero el que usa el programa puede cambiar (despido de empleado, nueva contratación), ¿y si ahora tiene menos conocimientos? ¿le quitas/modificas los mensajes de error porque no lo entiende?

Cita:

y si digo que si está pero está corrupto no le ayudo tampoco?
Lo primero que responderá al ver ese mensaje es: "coño, ¿la corrupción en Marbella se ha propagado tambien a este programa?"

Código:

  else
    begin
      ShowMessage('Error desconocido');
    end;

En este caso... mejor no decirle nada al usuario, o los ignorantes seremos nosotros.... "mira que hacer un programa y no saber el fallo" :D

Saludos

seoane 06-08-2006 15:57:13

Estoy de acuerdo contigo Lepe, yo cuando tengo que cargar una imagen ante cualquier excepción muestro el mensaje "No puedo cargar la imagen", si el usuario sabe lo que hace ya se imaginara porque es el fallo y si no lo sabe poco le vamos a aclarar dándole detalles técnicos. De todas formas siempre habra algun fallo que no se tuvo en cuenta y saldra el mitico mensaje de error: "Error desconocido" que da la sensacion de que el programador no sabia lo que estaba haciendo :D

Pero si te fijas yo empecé mi respuesta diciendo:
Cita:

Si lo que necesitas es información que te parece esto:
si no es imprescindible para que complicarle la vida al usuario con complejos mensajes de error.

dec 06-08-2006 16:12:16

Hola,

Cita:

Empezado por Lepe
(...) si despues necesitamos cargar un fichero de texto, hay que hacer algo parecido (las excepciones cambian) (...)

Pues de las que ha puesto Seoane más arriba creo que la única que "no valdría" sería la primera, pero, el resto me parecen a bote pronto perfectamente válidas para el caso de tener que cargar un archivo de texto.

Cita:

Empezado por Lepe
Cada operación a realizar puede involucrar fallos, intentar evitarlos todos te llevaría 4 veces más, en tiempo y presupuesto, ¿tu cliente estará de acuerdo?, en cuanto al dinero seguro que no. No queda más remedio que controlar "superficialmente" ese tipo de fallos.

No puedo estar de acuerdo. ¿Eso no sería parecido a no hacer que una página Web mantenga un código XHTML válido tan sólo porque el cliente no va a notar la diferencia? Puede que no note la diferencia, pero, es que tener un código "válido" también sirve al desarrollador del mismo, te lo aseguro. Por otro lado, ¿es más caro escribir código XHTML válido que HTML de cualquier manera? Creo firmemente que no.

Cita:

Empezado por Lepe
El usuario coge un archivo jpg, le cambia la extension a bmp (porque nuestro programa solo damos soporte a bmp) y .... ¿para eso le das un mensaje específico de ese fallo?... por dios, ese tipo sabe lo que hace; si no lo sabe y le da el error, pues le decimos que tiene que usar el paint [...] pero de ahí a controlar todos los errores que pueden dar... parece demasiado.

¿Y cómo se lo dices al usuario? ¿Con un mensaje, aunque no sea de error? Yo creo que el manejo de excepciones es una buena cosa, que habría que programar teniéndolo en cuenta y que esto puede ayudar no sólo al usuario, pero, como antes, también al desarrollador (y futuros desarrolladores) de un programa.

Ahora, es cuestión de "perder" la costumbre de hacerlo de otro modo: hay que recordar que las excepciones no están aquí desde siempre, que antes los errores se trataban de otro modo, pero, que, también, las excepciones han venido para quedarse... quiero pensar que por algo será... porque se las ve útiles: son una mejor forma de tratar los errores que como se hacía antes, a base de "prever" posibles problemas... esto suena muy complejo... ¡prever cualquier problema! Buf...

Cita:

Empezado por Lepe
El cliente te contrata para hacer un programa que "haga lo que él quiere" pero no pide un control exhasutivo de errores, es más.. decirle que se ha producido un error de "entrada / salida" le va a ayudar muy poco, creemé. Por otra parte los usuarios quieren programas sin tecnicismos, de lo contrario haces que parezcan ignorantes o tontos (aunque lo sean :D).

¿Porqué le vas a decir al cliente que existe un error de entrada/salida y nada más? Pero a ti puede venirte muy bien saber que existe un error de entrada/salida, por ejemplo, en un reporte de error que el propio programa podría encargarse de preparar e incluso enviar por correo, por ejemplo. Al cliente puede dársele esa información y alguna adicional, como, por ejemplo, "error de entrada/salida, probablemente el archivo que está tratando de abrir ya no existe en la ubicación especificada".

Cita:

Empezado por Lepe
A veces, viendo los conocimientos que tiene nuestro cliente de informática damos más o menos información... pero el que usa el programa puede cambiar (despido de empleado, nueva contratación), ¿y si ahora tiene menos conocimientos? ¿le quitas/modificas los mensajes de error porque no lo entiende?

Aquí volveré a repetir que el tratamiento de las excepciones en un programa no sólamente puede venirle bien al usuario del mismo, pero, a los propios desarrolladores. Pueden proporcionar información muy útil, y, bueno, se supone que las excepciones "se tratan", impiden que un programa entre en estado "de error" y se mantenga en cierto estado de "excepción" que puede controlarse.

Cita:

Empezado por Lepe
Lo primero que responderá al ver ese mensaje es: "coño, ¿la corrupción en Marbella se ha propagado tambien a este programa?"

Sí; puede que si a un usuario le dices de plano que un archivo está corrupto no entienda muy bien el mensaje, pero, vuelvo a lo de antes, siempre puede dársele la información "traducida" a un lenguaje, digamos, más comprensible... "El archivo que está intentando abrir parece corrupto. Esto generalmente significa que el contenido del archivo no puede ser leído correctamente. Disculpe las molestias, por favor, revise que el archivo seleccionado sea un archivo válido. Póngase en contacto con el soporte técnico si necesita ayuda." Puede parecer largo, si se quiere lo matizamos, pero, más o menos creo que se entiende la idea: trata al usuario como te gustaría que te trataran a ti.

Cita:

Empezado por Lepe
En este caso... mejor no decirle nada al usuario, o los ignorantes seremos nosotros.... "mira que hacer un programa y no saber el fallo" :D

Te refieres a si no puede averiguarse cuál es el error, problema o excepción, mejor dicho, con la que hemos topado, pero,... ¿no decirle nada al usuario le ayuda en algo? Se supone que el programa no podrá hacer su trabajo,... ¿y le dejamos al usuario con un palmo de narices? Además, pienso que no decirle nada al usuario impide algo importante: lo que el usuario pueda decirnos a nosotros... así que, si se trata de un error desconocido, bueno será saberlo, para empezar a tratar de conocerlo mejor... ;)

Disculpad el rollazo. Admito réplicas. :D :D

Lepe 06-08-2006 22:55:52

No, no pienso contestarte a todo ni replicarte, se me haría muy largo :D.

Mi criterio: Al usuario, los mínimos detalles técnicos posibles, si acaso procede, un código de error, (el numerito), simple para mí y simple para el usuario.

Crear tantos tipos de excepciones como haga falta en el programa, despues se muestran las que parezcan oportunas y las demás no. cualquier excepción al tiempo de realizar la facturación no se puede pasar por alto, Un Image1.LoadFromFile que despues se guarda en la base de datos, puede tratarse como antes he mencionado, revisa el código, en el except lanzo otra excepción :p.

Todas las excepciones a un archivo .TXT (y esto es muy importante). Si hace falta, que él mismo me lo envíe por correo. Recuerdas debuguear en tiempo de ejecución... pues eso ;).

¿Cuantas veces envías a Microsoft los fallos de Windows? ¿y de otros programas? Yo no me fío si lo que veo en pantalla es lo que se envía realmente, por eso, tomo la misma filosofía en mis programas.

Yo solo expongo lo que a mi parecer es lo más adecuado, podreís estar de acuerdo o no ;).

Saludos

Casimiro Notevi 06-08-2006 23:26:44

No había entrado en este hilo hasta ahora y he descubierto que está interesante.

Bueno, voy a dar mi opinión, que es un poco radical, y así se monta polémica :D

Soy partidario de dar al usuario la información mínima, clara y sencilla sobre lo que está haciendo, sobre su trabajo. Sin embargo, sobre asuntos técnicos, problemas, errores y todo eso... prefiero ocultárselo por completo.

Lo que hago es dirigir todos los mensajes de errores, excepciones, etc. a un fichero de texto (.log). En este fichero sí que guardo detallado el error producido, en qué módulo, qué se hacía en ese momento, valores de las variables implicadas, la fecha y hora, el error devuelto por el sistema, etc...

Si el usuario detecta algún problema o comportamiento anómalo, éste no verá ningún mensaje de error que le asuste ni ninguna excepción que le cierre el programa, pero sí que puede ver que ha ocurrido algo extraño, por ejemplo (por decir algo): el total de una factura no es igual a la suma de las líneas de ventas que la compone.

Lo que hago es mirar el fichero .log e intentar descubrir el problema según la información almacenada en el mismo.

Y es que no me gusta sacar información técnica al usuario porque no la entiende ni le sirve de nada. He visto casos de personas que me han llamado llorando (no exagero) ante una pantalla con un mensaje de error y pidiendo ayuda para que su jefe no le despida.

dec 07-08-2006 03:54:42

Hola,

Cita:

Empezado por Casimiro
Soy partidario de dar al usuario la información mínima, clara y sencilla sobre lo que está haciendo, sobre su trabajo. Sin embargo, sobre asuntos técnicos, problemas, errores y todo eso... prefiero ocultárselo por completo.

Vamos a ver, vamos a ver... ¿qué información técnica te parece un mensaje de error del tipo: "No se pudo abrir el archivo indicado. Por favor, asegúrese de que el mismo existe e inténtelo de nuevo. Contacte con el Servicio de Soporte si necesita ayuda. Disculpe las molestias".

¿Dónde está lo técnico ahí? Y nada te impide guardar (por otro lado) la información técnica que quieras para después poder consultarla si fuera menester. Como dices ahora:

Cita:

Empezado por Casimiro
Lo que hago es dirigir todos los mensajes de errores, excepciones, etc. a un fichero de texto (.log). En este fichero sí que guardo detallado el error producido, en qué módulo, qué se hacía en ese momento, valores de las variables implicadas, la fecha y hora, el error devuelto por el sistema, etc...

Cita:

Empezado por Casimiro
Si el usuario detecta algún problema o comportamiento anómalo, éste no verá ningún mensaje de error que le asuste ni ninguna excepción que le cierre el programa, pero sí que puede ver que ha ocurrido algo extraño, por ejemplo (por decir algo): el total de una factura no es igual a la suma de las líneas de ventas que la compone.

Alto. Aquí no puedo estar más en desacuerdo (creando polémica) ;)

Dices que no mostrarías al usuario mensaje de error alguno... ni ninguna excepción... que le cierre el programa... pero, un momento, ¿las excepciones no existen, entre otras cosas, para evitar el bloqueo del programa y su cierre obligatorio?

Eso tengo entendido: el programa entra en estado de excepción, estas pueden controlarse y el programa puede continuar adelante (siempre que sea posible, claro está).

Pero, lo que me parece curioso es que no informes al usuario del error y pretendas que él se dé cuenta de que hubo algún problema porque el total de una factura no cuadra con las cuentas que estaba haciendo el usuario...

Eso me parece muy peligroso, en el sentido de que el usuario puede pulsar ENTER para cerrar la ventana que le muestra la factura y ni fijarse siquiera en el total... porque se fía del programa, que, en caso de observar algún problema le avisaría como está mandado. :D :D :D

El caso es que si no revisara "manualmente" el resultado (¿Pero no están para eso los programas?) y cerrara la supuesta ventana y el programa no le dijera nada... pudiera estarse guardando en la base de datos (o ni guardarse siquiera) datos erróneos... ¡y el usuario aún creerá que no pasa nada, que todo va bien!

Tú luego irías con tu "log" y le dirías, mira, aquí esta factura puede que no cuadre, porque resulta que un error que... "¿Qué error?", te respondería el usuario, "No, tú es que no lo viste, pero, efectivamente...", "¿Cómo que no lo ví? ¿Y qué dices? ¿Que esta factura no está bien? ¡Pero si está cursada (o como se diga) junto con las del mes pasado? ¿cómo no se me informó del problema?... ¡Llámenme al responsable de este desaguisado!" Y se oiría por ahí... ¡Casimiro, ha sido el puñetero de Casimiro! :D :D

Total, pabernosmatao. ;)

Lepe 07-08-2006 10:19:33

Al salir una excepción programada por mi, he visto como el usuario, como acto reflejo, pulsaba el botón de aceptar; me quedé alucinado, la ventana no se había terminado de dibujar y ya había pulsado Aceptar.

Su respuesta fue que "esa ventanita no era nada", estupendo... me harto de estudiar el flujo del programa ante excepciones y solo consigo mejorar los reflejos de los usuarios....

Si un coche se para, lo llevas al taller, si un programa da un fallo, "no es nada" y si se queda colgado se apaga y se enciende de nuevo.... problema resuelto :eek:.

Saludos


La franja horaria es GMT +2. Ahora son las 15:33:31.

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