Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

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

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 18-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
formateo de Dato en Dbgrid

Hola a todos

Trabajo con Delphi 7
tengo una dbgrid y necesito condicionar el formato
Si el dato es > 0, darle el sgte formato "0.0000" de lo contario dejarlo en blanco,
pero nose como llegar a cambiar formato, si he llegado a cambiar el color
pero el formato no he podido....

me imagino que debo trabajar con el evento
dbgriddrawcolumncell....
o estoy equivocada???

muchas gracias de antemano....
Responder Con Cita
  #2  
Antiguo 18-08-2010
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
Me imagino que en el evento onChange del dataset asociado al campo.
Saludos
__________________
Siempre Novato
Responder Con Cita
  #3  
Antiguo 18-08-2010
Avatar de Chris
[Chris] Chris is offline
Miembro Premium
 
Registrado: abr 2007
Ubicación: Jinotepe, Nicaragua
Posts: 1.678
Poder: 19
Chris Va por buen camino
Para hacer lo que quieres, el objeto TField proporciona el evento OnGetText. Tienes que crear un evento del tipo TFieldGetTextEvent. Luego asignalo a la propiedad del campo al que quieres cambiar el formato después que el dataset contenedor sea abierto. En el evento TFieldGetTextEvent que hayas creado escribirás el código en donde proporcionaras el formato que tendrá tu campo.

Saludos,
Chris
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
  #4  
Antiguo 18-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola BPL.

Coincido con Chris en el evento a capturar.

El código que te pongo, lo podés asignar a cualquier campo numérico:
Código Delphi [-]
procedure TForm.FieldGetText(Sender: TField; var Text: string;
  DisplayText: Boolean);
begin
  if TField(Sender).Value > 0 then
    Text:= FormatFloat('0.0000',TField(Sender).Value);
end;

Podés asignarlo con doble click sobre el evento del campo asociado o mediante código:
Código Delphi [-]
   TuTabla.FieldByName('Puntos').OnGetText:= FieldGetText;
   // o si el campo está declarado:
   TuTablaTuCampo.OnGetText:= FieldGetText;



Saludos.

Última edición por ecfisa fecha: 18-08-2010 a las 22:06:20.
Responder Con Cita
  #5  
Antiguo 19-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
gracias ChHris y Ecfisa, ver el codigo me sirvio un poco mas, pero igual algo debo estar haciendo malo, porque no logro compilar, me reclama que faltan parametros, y a simple vista si me faltan, pero no logro llegar a lo correcto.

me podrian ayudad un poquito mas.....
Responder Con Cita
  #6  
Antiguo 19-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola de nuevo.

No especificás mcuho hacerca del error..., pero será sobre el evento OnGetText no ?

De ahora en más me voy a referir al campo involucrado como: tuCampo.

1) Hacé doble click sobre la tabla involucrada, eso te abre el editor de campos.
2) Hacé click con botón derecho del mouse y elegí: Add all fields de la ventana emergente.
3) Hacé click sobre tuCampo.
4) En el Object Inspector hacé click sobre la pestaña Events.
5) Hacé doble click sobre el evento OnGetText.
6) Te va a haber creado el esqueleto del procedimiento y dejado en el editor de Delphi de este modo:
Código Delphi [-]
procedure TForm1.Table1TuCampoGetText(Sender: TField; var Text: String;
  DisplayText: Boolean);
begin

end;

Dentro de él, pegá el siguiente código:

Código Delphi [-]
  if TField(Sender).Value > 0 then
    Text:= FormatFloat('0.0000',TField(Sender).Value);



Saludos.

Última edición por ecfisa fecha: 19-08-2010 a las 02:59:51.
Responder Con Cita
  #7  
Antiguo 19-08-2010
Loviedo Loviedo is offline
Miembro
 
Registrado: dic 2004
Posts: 214
Poder: 0
Loviedo cantidad desconocida en este momento
Has probado con la propiedad DisplayFormat?.
Yo la uso y me funciona.
Saludos.
Responder Con Cita
  #8  
Antiguo 19-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
Chicos,
Haber parece que mi error fue no explicarme bien,

estoy trabjando con una SQL (creada en tiempo de ejecucion)
el resultado de esta SQL, la muestro en una dbgrid,
uno de los campos es Espesor.
Ahora lo que necesito es que "solo" cuando el dato es mayor a 0 lo formatee asi "0.0000" de lo contario no muestre nada.

por el minuto lo estoy haciendo con el displayformat despues de abrir la SQL

" (FieldByName('Espesor') AS TFloatField).DisplayFormat := '#.####' "
pero el problema es que me muestra de esta manera .010 y necesita que se muestre completa 0.0100 pero si no hay dato no muestra nada......
por eso yo creo que va mas por el onDrawColumnCell, ya que el formato no es para toda la columna de una vez sino personalizada para cada dato...

espero me hallan logrando entender ahora....

gracias por la atencion prestada...y espero que me siguan ayudando.,...
Responder Con Cita
  #9  
Antiguo 19-08-2010
Loviedo Loviedo is offline
Miembro
 
Registrado: dic 2004
Posts: 214
Poder: 0
Loviedo cantidad desconocida en este momento
FieldByName('Espesor') AS TFloatField).DisplayFormat := '0.0000';
Me aparece 0,0010.
saludos.
Responder Con Cita
  #10  
Antiguo 19-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
pero cuando no existe dato me saldria 0.0
y es eso lo que precisamente no debe ocurrir,
insisto debe salir blanco nada....
Responder Con Cita
  #11  
Antiguo 19-08-2010
Loviedo Loviedo is offline
Miembro
 
Registrado: dic 2004
Posts: 214
Poder: 0
Loviedo cantidad desconocida en este momento
Uso Firebird y tengo dos campos numericos (debe,haber), de tal modo que si uno de los campos no contiene nada no almacena 0, sino null. En el dbgrid el campo que tiene almacenado null, no aparece en el otro sí, según displayformat.
Saludos.
Responder Con Cita
  #12  
Antiguo 19-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
no en mi caso no pasa eso,
como antecedente yo trabajao con Delphi 7 + Advantage (motor)

pucha.....
Responder Con Cita
  #13  
Antiguo 19-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
Empezado por BPL Ver Mensaje
no en mi caso no pasa eso,
como antecedente yo trabajao con Delphi 7 + Advantage (motor)

pucha.....
BPL...

No importa si trabajas sobre un TTable o TQuery, en definitiva estamos hablando de un TField.
En el post puse un TTable como ejemplo, pero lo mismo vale para un TQuery.

Repetí los pasos que te puse sobre el TTable en el TQuery y me contás.

Saludos.
Responder Con Cita
  #14  
Antiguo 19-08-2010
Avatar de BPL
BPL BPL is offline
Miembro
 
Registrado: ene 2009
Posts: 47
Poder: 0
BPL Va por buen camino
Ando super perdida, no entender nada...

mira aqui te muestro como lo escribi.....y mas abajito te explico...

Procedure GrillaDrawColumnCell(Sender: TObject;const Rect: TRect; DataCol: Integer; Column:TColumn; State: TGridDrawState);
begin
if (Grilla.DataSource.DataSet['Espesor'] > 0 ) then begin
Grilla.DataSource.DataSet['Espesor'].OnGetText := qrCotDetalleEspesorGetText ;
end;


Procedure qrDetalleEspesorGetText(Sender:TField; var Text:string; DisplayText:Boolean) ;
Begin
if TField(sender).Value > 0 Then
Text := FormatFloat('0.0000',TField(Sender).Value) ;
end ;



en el evento DrawColumnCell de la Grilla (GrillaDrawColumnCell), aqui es la instancia en donde necesito evaluar el dato, por decir algo aqui se esta dibujando la grilla.
al compilar asi como esta escrito arriba, me reclama por falta de parametros en "qrCotDetalleEspesorGetText", que a simple vista si me faltan...
despues de alguna manera agrego los parametros que faltan, compilo y me sale el sgte msg de error

project sisventas.exe raised exception class EVariantInvalidOpError with message "Invalid variant operation'.

y lo otro que no logro entender, como replico lo que tu me explicas en el post, con respecto hacer click en tabla, add all fields, evento, onGetText, mi tabla o query no existe hasta que se ejecuta el programa....
igual trate de hacer algo pero no di.,....


pucha ojala no te aburras,,, y sigas tratando de explicarme....

Responder Con Cita
  #15  
Antiguo 20-08-2010
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
No te preocupes, si me aburriera no estaría aca leyendo...

Olvidate por completo de la Grilla,este código no vá:
Código Delphi [-]
{
Procedure GrillaDrawColumnCell(Sender: TObject;const Rect: TRect; DataCol: Integer; Column:TColumn; State: TGridDrawState);
begin
if (Grilla.DataSource.DataSet['Espesor'] > 0 ) then begin
Grilla.DataSource.DataSet['Espesor'].OnGetText := qrCotDetalleEspesorGetText ;
end;
}

En el Form donde tengas la Tabla o Query, hacé esto:
Código Delphi [-]
procedure TForm.Create(Sender: TObject);
begin
   Query1.FieldByName('Espesor').OnGetText:= FieldGetText;
   // o si es Table:
   Table1.FieldByName('Espesor').OnGetText:= FieldGetText;
end;

Ahora ya tenemos asignado el procedimiento FieldGetText al evento OnGetText del campo 'Espesor', así que escribimos el procedimiento:
Código Delphi [-]
procedure TForm.FieldGetText(Sender: TField; var Text: String;DisplayText: Boolean);
begin
  if TField(sender).Value > 0 Then
       Text := FormatFloat('0.0000',TField(Sender).Value) ;
end;

La asignación al evento OnGetText del campo 'Espesor' se produce cuando se crea el Form y ya está, no hay que asignarlo a cada dibujo de la Grilla.

Ante cualquier duda, escribí nuevamente.


Saludos.
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
Mascara de un dato en un Dbgrid sancarlos OOP 2 21-07-2008 20:09:40
Capturar un dato de un dbgrid SaLvaGe Conexión con bases de datos 5 15-09-2005 19:26:17
guardar en variable dato de un dbgrid el_barto Conexión con bases de datos 2 30-07-2005 14:41:04
extraer un dato de un dbgrid detybel Conexión con bases de datos 4 26-03-2005 06:01:45
Mostrar un dato de un DBGrid en un Edit marial Conexión con bases de datos 3 03-06-2004 21:40:41


La franja horaria es GMT +2. Ahora son las 05:07:30.


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