AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Im DBEdit ein String in ein Date umwandeln
Thema durchsuchen
Ansicht
Themen-Optionen

Im DBEdit ein String in ein Date umwandeln

Ein Thema von ickehausen · begonnen am 20. Mai 2008 · letzter Beitrag vom 20. Mai 2008
Antwort Antwort
ickehausen

Registriert seit: 29. Jul 2004
85 Beiträge
 
Delphi 2010 Enterprise
 
#1

Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 12:06
Datenbank: Firebird • Version: 2.1 • Zugriff über: ibx
Hallo Leute,

in meiner Firebird-Datenbank möchte ich ein Date-Feld über ein DBEdit füllen. Nun würde ich gern in das DBEdit auch ein 'h' eingeben können, welches dann in das aktuelle Datum umgewandelt wird. Analog dazu 'g' und 'm' für gestern und morgen. Ich versuche es mit dem onExit-Ereignis der DBEdit-Komponente wie folgt und erhalte beim Verlassen der DBEdit-Komponente eine Exception der Klasse EConvertError mit der Meldung ''h' ist kein gültiges Datum'.

Delphi-Quellcode:
procedure TForm1.DBEditVDatumExit(Sender: TObject);
begin
  dat := DBEditVDatum.EditText;
  if dat = 'h'  then
    DBEditVDatum.EditText := DateToStr( Date());
end;
Ersetze ich das 'h' durch '' und lasse das DBEdit frei, fügt mir meine Anwendung das aktuelle Datum ein!?

Kann mir jemand helfen?
Es gibt keine dummen Fragen ...
  Mit Zitat antworten Zitat
bluesbear

Registriert seit: 14. Dez 2005
Ort: Hahnstätten
355 Beiträge
 
Delphi 2007 Enterprise
 
#2

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 12:13
Versuche doch mal, in OnKeyPress den jeweiligen Buchstaben abzufangen.
Klaus M. Hoffmann
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 12:18
Soll direkt nach Eingabe das Datum im Edit erscheinen oder beim Einfügen in die DB?
Markus Kinzler
  Mit Zitat antworten Zitat
ickehausen

Registriert seit: 29. Jul 2004
85 Beiträge
 
Delphi 2010 Enterprise
 
#4

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 12:26
Danke bluesbaer,

Du hast mich auf den richtigen Weg gebracht. Mit onChange geht es jetzt:

Delphi-Quellcode:
procedure TForm1.DBEditVDatumChange(Sender: TObject);
begin
  dat := DBEditVDatum.EditText;
  if dat = 'h'  then
    DBEditVDatum.EditText := DateToStr( Date());
  if dat = 'm'  then
    DBEditVDatum.EditText := DateToStr( Date()+1);
  if dat = 'g'  then
    DBEditVDatum.EditText := DateToStr( Date()-1);
end;
So wird direkt bei der Eingabe das Datum umgewandelt.
Es gibt keine dummen Fragen ...
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 12:39
Die technisch beste Lösung wäre, nicht am Control TDBEdit anzusetzen, sondern am Feld.
Dazu wird ein Eventhandler für OnSetText bereitgestellt:
Delphi-Quellcode:
procedure TForm1.DateFieldOnSetText(Sender: TField; const Text: String);
begin
  if Text = 'h'  then
    Sender.AsDateTime := DateToStr( Date())
  else if Text = 'm'  then
    Sender.AsDateTime := DateToStr( Date()+1.0)
  else if Text = 'g'  then
    Sender.AsDateTime := DateToStr( Date()-1.0)
  else
    Sender.AsString := Text;
end;
Vorteil: das funktioniert jetzt nicht nur mit einem DBEdit sondern auch mit TDBGrid.
Ausserdem ist es möglich alle Date-Felder über eine Schleife abzugrasen und den Eventhandler zuzuweisen.
Andreas
  Mit Zitat antworten Zitat
ickehausen

Registriert seit: 29. Jul 2004
85 Beiträge
 
Delphi 2010 Enterprise
 
#6

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 13:42
shmia, danke für den weiteren Tip. Es darf dann aber nicht mit DateToStr umgewandelt werden, sonst erhalte ich eine Fehlermeldung inkompatible Variablen-Typen

Delphi-Quellcode:
procedure TDataModule2.IBDataSetMainVERNICHTUNGSDATUMSetText(Sender: TField;
  const Text: string);
begin
  if Text = 'h'  then
    Sender.AsDateTime := ( Date())
  else if Text = 'm'  then
    Sender.AsDateTime := ( Date()+1.0)
  else if Text = 'g'  then
    Sender.AsDateTime := ( Date()-1.0)
  else
    Sender.AsString := Text;
end;
Es gibt keine dummen Fragen ...
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#7

Re: Im DBEdit ein String in ein Date umwandeln

  Alt 20. Mai 2008, 13:46
Zitat von ickehausen:
Es darf dann aber nicht mit DateToStr umgewandelt werden, sonst erhalte ich eine Fehlermeldung inkompatible Variablen-Typen
Ja, klar. Ich tippe meinen Code meistens ungetestet ein, da kann sowas schol mal passieren.
Andreas
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:28 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz