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 13-05-2011
ZiriusB ZiriusB is offline
Miembro
 
Registrado: oct 2010
Posts: 86
Poder: 14
ZiriusB Va por buen camino
Exclamation Dos decimales en un TEDIT

Buenas, he visto algunos temas con respecto a esto pero ningun ejemplo me funciona, quiero que un TEDIT solo posea dos decimales, el resultado del TEDIT es la suma de varios TEDIT...

estoy usando el siguiente codigo:

Código Delphi [-]
procedure TForm2.CalcularNClick(Sender: TObject);
begin
npromedio.text:= Format('%0:2f',[npromedio.Text]);
npromedio.Text:=  Floattostr(StrToFloat(edit1.Text)+StrToFloat(edit2.Text)+StrToFloat(edit3.Text)+StrToFloat(edit4.Tex  t));
end;


Cita:
First chance exception at $7C812AEB. Exception class EConvertError with message 'Format '%0:2f' invalid or incompatible with argument'. Process Eval.exe (3104)
Espero puedan darme alguna ayuda, Gracias
__________________
"Ningun precio es alto por el privilegio de ser uno mismo..."

Última edición por Caro fecha: 13-05-2011 a las 17:24:37.
Responder Con Cita
  #2  
Antiguo 13-05-2011
Avatar de Caro
*Caro* Caro is offline
Moderadora
 
Registrado: jul 2004
Ubicación: Cochabamba, Bolivia
Posts: 2.544
Poder: 22
Caro Va por buen camino
Hola, primero tienes que sumar y despues darle formato y convertir lo que tienes en tu edit, también puedes usar FormatFloat.

Código Delphi [-]
 npromedio.Text:=  Floattostr(StrToFloat(edit1.Text)+StrToFloat(edit2.Text)+StrToFloat(edit3.Text)+StrToFloat(edit4.Tex  t));
 npromedio.text := Format('%0:2f',[StrToFloat(npromedio.Text)]);
 //con formatfat
 npromedio.text := FormatFloat('0.00',StrToFloat(npromedio.Text));

Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar.
Responder Con Cita
  #3  
Antiguo 13-05-2011
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 ZiriusB.

En esta línea:
Código Delphi [-]
   npromedio.text:= Format('%0:2f',[npromedio.Text]);
Estas indicando en el formato de salida que el valor es un Float (2f) y le estas enviando un TCaption (Text).

Para lograr lo que buscas, probá de hacerlo de este modo:
Código Delphi [-]
procedure TForm2.CalcularNClick(Sender: TObject);
begin
  npromedio.Text:= FormatFloat('0.00',StrToFloat(npromedio.Text));
  npromedio.Text:= FormatFloat('0.00',StrToFloat(FloatToStr(StrToFloat(edit1.Text)
                   +StrToFloat(Edit2.Text)+StrToFloat(Edit3.Text)+StrToFloat(Edit4.Text))));
end;
Tomá en cuenta que la segunda línea anula el valor asignado en la primera.

Saludos.

Edito: Lamento casi duplicar la respuesta pero no estaba el mensaje de Caro cuando empezé a escribir...
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 13-05-2011 a las 17:55:21.
Responder Con Cita
  #4  
Antiguo 18-05-2011
ZiriusB ZiriusB is offline
Miembro
 
Registrado: oct 2010
Posts: 86
Poder: 14
ZiriusB Va por buen camino
Muchas gracias por su respuesta, lo implemente hace dias pero no habia tenido la oportunidad de responder...tengo un problema y lo planteo aqui para no abrir otro tema espero no este cometiendo una falta, es sobre la misma base de este!

a NPROMEDIO.TEXT yo lo quiero guardar en mi base de datos SQL, tengo asignado el valor como "FLOAT" en la base de datos, sin embargo a la Hora de guardar me da un error:

Cita:
First chance exception at $7C812AEB. Exception class EOleException with message 'There are fewer columns in the INSERT statement than values specified in the VALUES clause. The number of values in the VALUES clause must match the number of columns specified in the INSERT statement'. Process Eval.exe (2560)
El hecho es que he revisado y volteado el codigo y todo esta bien, estan los mismos valores en INSERT que en las clausulas.

Tengo una funcion de redondeo para NPROMEDIO.TEXT que estaba desactivada, cuando la activo y el numero se redondea lo guarda sin problemas pero si la desactivo me vuelve a aparecer el mismo problema...

El valor de NPROMEDIO.TEXT lo estoy guardando asi:

Código Delphi [-]
    ADOguardar.SQL.Add(FloattoStr(Strtofloat(npromedio.Text)));
    ADOguardar.SQL.Add(',');

No se si sera un problema con la conversion que le doy aqui:

Código Delphi [-]
npromedio.text := FormatFloat('0.00',StrToFloat(npromedio.Text));

Espero puedan guiarme... y una vez mas mil gracias por la ayuda!
__________________
"Ningun precio es alto por el privilegio de ser uno mismo..."
Responder Con Cita
  #5  
Antiguo 19-05-2011
Avatar de Caral
[Caral] Caral is offline
Miembro Premium
 
Registrado: ago 2006
Posts: 7.659
Poder: 25
Caral Va por buen camino
Hola
No veo el codigo completo del query ADOguardar.
Sin verlo es algo dificil opinar que podria estar pasando.
Saludos
__________________
Siempre Novato
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
decimales anoniboxx C++ Builder 9 19-04-2010 19:15:09
TEdit, que admita sólo números con 2 decimales David OOP 5 09-02-2008 17:09:58
TEdit Io Varios 3 23-08-2007 21:12:29
Pasar el valor de un TEdit dentro de un StringGrid a otro TEdit que está fuera atirado Varios 4 11-09-2004 19:13:48
TEdit RoyTan Varios 5 26-11-2003 21:12:33


La franja horaria es GMT +2. Ahora son las 20:36:54.


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