Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 21-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Red face Controlar edición de DBEdit

Hola a todos, estoy creando una app con C++ Builder y tengo un formulario que obtiene información de una BD de MySql mediante algunos DBEdit, muestra un campo de tipo flotante con 2 decimales, mi duda es........cómo controlo de manera manual que el usuario ingrese un flotante válido en ese DBEdit? Me explico, ya restringí mediante evento OnKeyPress, que el usuario sólo ingrese números y el punto decimal, pero al ingresa por ejemplo: 4.50.2 es el sistema que me arroja el mensaje de error (en inglés), lo que quiero es manejar de manera manual ese mensaje de error para mostrar un texto que yo desee, si no me equivoco, el término correcto sería "validar" manualmente ese dato editado. Gracias
Responder Con Cita
  #2  
Antiguo 22-06-2021
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.282
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Yo creo que lo más sencillo es que no intentes controlar los errores en la entrada del usurio, sino que esperes a que la Base de Datos te devuelva el error, lo captures y lo muestres.
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Cita:
Empezado por Neftali [Germán.Estévez] Ver Mensaje
Yo creo que lo más sencillo es que no intentes controlar los errores en la entrada del usurio, sino que esperes a que la Base de Datos te devuelva el error, lo captures y lo muestres.
Gracias por tu respuesta, sería una opción, pero el problema es q al momento de que el DBEdit en cuestion pierde el foco y pasar a otro componente, ya me marca el error, traté de utilizar el evento OnExit del DBEdit y tampoco resulta, al parecer se verifica el dato antes de dispararse OnExit, así que no me dejaría probar lo que tu mencionas.
Adjunto una captura, al momento de editar el Precio de compra y querer pasar al sgte, me salta ese error, q claro, es lo correcto, pero un usuario q no sepa inglés no va a entender el mensaje de error.
Imágenes Adjuntas
Tipo de Archivo: jpg Captura5.jpg (37,9 KB, 5 visitas)
Responder Con Cita
  #4  
Antiguo 22-06-2021
Avatar de movorack
[movorack] movorack is offline
Miguel A. Valero
 
Registrado: feb 2007
Ubicación: Bogotá - Colombia
Posts: 1.346
Poder: 20
movorack Va camino a la famamovorack Va camino a la fama
Al ser un DBEdit, estará asociado a un dataset y en este se puede realizar la validación que buscas en el evento OnValidate del campo "precioc_prod".

Si no tienes persistentes los campos en el dataset, sería agregarlos en tiempo de diseño. Y esto te daría la opción de establecer el código de ese evento.
__________________
Buena caza y buen remar... http://mivaler.blogspot.com
Responder Con Cita
  #5  
Antiguo 22-06-2021
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.

Una opción es interceptar el evento OnSetText del campo asociado que se dispara cada vez que se recibe un nuevo valor pero antes de ser asignado.

Por ejemplo, si el campo asociado al DBEdit se llamase "Numero":
Código Delphi [-]
procedure TuForm.TuDataSetNumeroSetText( Sender: TField; const Text: string );
var
  e: Extended;
begin
  if not TryStrToFloat( Text, e ) then
    raise Exception.Create( 'No es un número decimal válido' );
end;

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #6  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Traté con tu código, en lo que equivaldría a c++ builder, pero me arroja error en la línea donde creas la excepción, que creo q eso es lo que necesito, de casualidad no sabes el código para el C builder? O qué es lo que estaría haciendo mal yo?

Código:
void __fastcall Tdmquerys::qdetdetallespreciov_prodSetText(TField *Sender, const UnicodeString Text)

{
	Extended e;
	if(!(TryStrToFloat(fdetprod->dbedetpc->Text, e))){
		//La excepción     raise Exception.Create( 'No es un número decimal válido' );
	}
}
Aclaro, el DBEdit lo tengo en un Form(fdetprod), y la información se llena desde un DataSet conectado a un ADOQuery (qdetdetalles).
Gracias por responder
Responder Con Cita
  #7  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Cita:
Empezado por movorack Ver Mensaje
Al ser un DBEdit, estará asociado a un dataset y en este se puede realizar la validación que buscas en el evento OnValidate del campo "precioc_prod".

Si no tienes persistentes los campos en el dataset, sería agregarlos en tiempo de diseño. Y esto te daría la opción de establecer el código de ese evento.

A qué te refieres con campos "persistentes"? Investigando me topé con ese término, pero no encontré info.....entendible jeje
Responder Con Cita
  #8  
Antiguo 22-06-2021
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.
Cita:
Empezado por isracdc Ver Mensaje
...de casualidad no sabes el código para el C builder? ...
No tengo C++ Builder en este momento pero intenta de este modo:
Código PHP:
...
   throw 
Exception"No es un número decimal válido" ); 
Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #9  
Antiguo 22-06-2021
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.

Y en tu código podes usar el parámetro Text directamente:
Código PHP:
void __fastcall Tdmquerys::qdetdetallespreciov_prodSetText(TField *Sender
  const 
UnicodeString Text)
{
  
Extended e;
  if ( !( 
TryStrToFloatText) ) )
  ... 
Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #10  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola.


No tengo C++ Builder en este momento pero intenta de este modo:
Código PHP:
...
   throw 
Exception"No es un número decimal válido" ); 
Saludos

Genio!!!! Si, me ha resultado, eso era lo que estaba necesitando, muchas gracias

void __fastcall Tdmquerys::qdetdetallesprecioc_prodSetText(TField *Sender, const UnicodeString Text)

Código:
{
	Extended e;
	if(!(TryStrToFloat(fdetprod->dbedetpc->Text, e))){
		throw Exception( "No es un número decimal válido" );

}
Dejo el pequeño código por si a alguien le sirve.
Gracias y saludos
Responder Con Cita
  #11  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola de nuevo.

Y en tu código podes usar el parámetro Text directamente:
Código PHP:
void __fastcall Tdmquerys::qdetdetallespreciov_prodSetText(TField *Sender
  const 
UnicodeString Text)
{
  
Extended e;
  if ( !( 
TryStrToFloatText) ) )
  ... 
Saludos
Una duda más, que pasaría en el else? O cúal sería la sentencia que controla lo que pasa si es q la condición if ( !( TryStrToFloat( Text, e ) ) ) de resultado Falso? Es decir, cuál sería el código q indique que....."El dbeedit se llena normalmente"?
Responder Con Cita
  #12  
Antiguo 22-06-2021
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.

Si TryStrToFloat devuelve verdadero ( el numero es correcto ) continúa con el flujo del programa, en caso contrario lanza la excepción.

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #13  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Exclamation

Eso creí, pero, mi pregunta iba porque lanza la excepción correctamente, pero ahora, al colocar un valor correcto, el DBEdit vuelve al valor que tenía de inicio, es como si se refrescara y no queda el valor q edité (ReadOnly está en False, por si acaso )
Responder Con Cita
  #14  
Antiguo 22-06-2021
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.

Ahora te entiendo, no tengo como probarlo pero creo que sería:
Código PHP:
...
  if ( !( 
TryStrToFloatText) ) )
    throw 
Exception"No es un número decimal válido" );
  else
     
Sender->AsString Text
Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #15  
Antiguo 22-06-2021
isracdc isracdc is offline
Miembro
 
Registrado: nov 2015
Posts: 24
Poder: 0
isracdc Va por buen camino
Cita:
Empezado por ecfisa Ver Mensaje
Hola.

Ahora te entiendo, no tengo como probarlo pero creo que sería:
Código PHP:
...
  if ( !( 
TryStrToFloatText) ) )
    throw 
Exception"No es un número decimal válido" );
  else
     
Sender->AsString Text
Saludos

Exacto! Eso era lo q faltaba, ahora si funciona todo correctamente, mil gracias!
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
asignar contenido de un DBedit a otro DBedit Richardn Varios 4 29-11-2012 17:06:03
Edición de IP FerCastro Varios 2 10-03-2007 00:46:59
Edición de un DBGRID luxus Conexión con bases de datos 1 13-02-2007 11:34:26
Como puedo cambiar la propiedad de edicion y no edicion a un StringGrid1 ctronx Varios 2 25-06-2004 23:10:19


La franja horaria es GMT +2. Ahora son las 01:14:16.


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