Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   ayuda con una comparacion if (https://www.clubdelphi.com/foros/showthread.php?t=77709)

danielmj 21-02-2012 12:25:19

ayuda con una comparacion if
 
Hola, estoy aqui comiendome el coco con este trozo del codigo que aun siendo una tonteria me trae loco, y os pido ayuda :)
El codigo es este...

Código Delphi [-]
for i:= 0 to cmbfecha.Items.Count do
begin     
  label1.caption:= DateToStr(now);     
  if (cmbFecha.Items.Text = label1.Caption) and //(DateToStr(now))) and  (TimeToStr(now) < '10:18:00') then         
    label2.caption:= IntToStr(i)          
  else
    ...      

end;

Si omito la linea
Código Delphi [-]
label1.caption:= DateToStr(now);

y en el if hago la comparacion directamente con un
Código Delphi [-]
dateToStr(now)

no devuelve ningun valor, pero si comparo de esta manera si:
Código Delphi [-]
if (cmbFecha.Items.Text = label1.Caption)

¿por que?

y por otra parte, según está el codigo, si cambio los valores de la hora y el signo de mayor o menor para que la comparacion sea negativa, me sigue mostrando la fecha actual en la etiqueta lo cual no deberia pasar al no cumplirse una de las condiciones.

¿Alguien puede ayudarme?

gracias.

newtron 21-02-2012 13:19:23

¿Algún mode que ponga ese código legible? :D

danielmj 21-02-2012 14:11:37

Pues perdon, no se que ha pasado, use las etiquetas para codigo delphi y cuando le di a previsualizar se veia estructurado correctame, de todos modos he intentado editar mi mensaje pero no veo la opcion por ninguna parte. Asi que habro un nuevo hilo y que un moderador elimine este. Lo siento.

Perdon y a ver si me podeis ayudar.

Casimiro Notevi 21-02-2012 14:31:44

No repitas mensajes, recuerda nuestra guía de estilo, gracias.

Borro el otro.

Si no puedes editarlo, avisa y cualquier moderador lo hace.
Y en todo caso, vuelve a escribirlo aquí, no abras un nuevo hilo.

danielmj 21-02-2012 15:14:24

vale casimiro, una vez mas perdon, no pretendo molestar ni entorpecer el foro.

un saludo.

Casimiro Notevi 21-02-2012 15:46:12

Cita:

Empezado por danielmj (Mensaje 425656)
vale casimiro, una vez mas perdon, no pretendo molestar ni entorpecer el foro.
un saludo.

No te preocupes, es sólo que lo tengas en cuenta para las futuras consultas :)

Al González 21-02-2012 15:56:51

Hola Daniel.

¿Podrías poner el código de cada caso en particular? (veo que mencionas al menos dos situaciones). Para entender mejor el problema.

Gracias. :)

luisgutierrezb 21-02-2012 16:17:37

Independientemente del código, yo te haría una recomendación no compares strings, mejor convierte la hora a datetime y compara con la hora de now recuerda que con los strings son especiales por llamarles de algún modo

danielmj 21-02-2012 17:43:04

Hola, para no meter la pata con la estructura del codigo he preferido hacerle una captura y ponerla en internet, asi me aseguro que se ve bien.



Ahora el problema... básicamente lo que me ocurre es que cuando comparo el contenido del combobox con la instrucción "DateToStr(now)", no devuelve nada, pero si antes por ejemplo en una etiqueta, le asigno el valor del DateTo...(now), y realizo la comparacion entre el contenido del combo y el de la etiqueta, si devuelve un valor. Y no entiendo cual es la diferencia si realmente es lo mismo, solo que uso la etiqueta como "puente".

Por otra parte, y usando la etiqueta para realizar la comparación con el if, me devuelve un valor aunque no se cumplan las dos condiciones. Y ahí me tiene to pillao jeje.
Por cierto, las partes del codigo que estan como comentarios estan así aunque realmente exista un proceso "enviar.click" por que antes quiero solucionar esto que esta pasando, una vez arreglado ya dejaran de ser comentarios.

un saludo y gracias.

Al González 21-02-2012 17:58:32

No sé por qué con el "puente" Label1 no ocurre lo mismo que sin él (habría que ver el código exacto de cómo lo haces sin ese puente ;)).

Lo que sí veo algo extraño es que tomes todos los elementos concatenados del cuadro combinado, cmbFecha.Items.Text, en lugar de tomar solamente el elemento de la posición I: cmbFecha.Items [i]. ¿Será eso? :)

Te invito a hacer este experimento:

Código Delphi [-]
ShowMessage (cmbFecha.Items.Text);
ShowMessage (cmbFecha.Items [0]);

Un curioso abrazo.

Al.

Caral 21-02-2012 18:25:00

Hola
1-La comparación se saca de un dato Texto (combobox).
2-La comparación es de un solo dato, osea, no de varios ITEMS del combobox.
3-La hora si es Time no se podrá comparar con un string (tal como lo pretendes hacer).

Código Delphi [-]
var
 i: integer;
 Fecha, Hora : String;
begin
  Fecha:= FormatdateTime('mm/dd/yyyy',(now));
  Hora:= FormatdateTime('hh:nn:ss',(now));
  for i:= 0 to cmbfecha.Items.Count do
begin
  if (cmbFecha.Text = Fecha)
  and  (Hora < '10:18:00') then
  label2.caption:= IntToStr(i);
end;
end;

Saludos

Chris 21-02-2012 18:31:11

Hola!

Antes que todo, que condiciones se deben haber para que "(TimeToStr(Now) < '10:18:00')" devuelva True?.

Con respecto a lo anterior, mi punto es que te fijes que en realidad estás comparando dos cadenas de texto, no dos fechas. Por lo que utilizar el operador < para cadenas de texto es demasiado ambiguo.

Creo que tu código, casi es su totalidad está mal en conceptos, pues estás utilizando cadenas de texto para hacer comparaciones de fechas. Aún que conviertas correctamente las fechas y horas a texto, tienes que tener en cuenta que esto depende de la configuración regional. No puedes esperar que TimeToStr(Now) devuelva siempre '10:18:00', ya que te podría devolver "10:18:10 AM o PM" y muchas otras variaciones. Lo mejor es que siempre trabajes con fechas y horas de forma nativa.

Código Delphi [-]
var
    I: Integer;
    cmbDate: TDate;
begin
    for I := 0 to (cmbFecha.Items.Count - 1) do
    begin
        
        cmbDate := StrToDate(cmbFecha.Items[i]);
        
        if cmbDate = Date then
        begin
            // comparar hora
            if (CompareDate(Now, EncodeTime(10, 18, 0, 0)) = LessThanValue) then
                Label2.Caption := IntToStr(I);
        end
        else
            ...
        
    end;
end;

Talvez ese código te sirva. Pruebalo, que no estoy seguro que te sirva al 100%.

Saludos!


La franja horaria es GMT +2. Ahora son las 18:27:49.

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