Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Float Edit-Feld (https://www.delphipraxis.net/165890-float-edit-feld.html)

ByTheTime 19. Jan 2012 22:03

Float Edit-Feld
 
Hallo,
der Titel ist vllt. etwas unpassen... Ich habe folgendes Problem:

Meine Anwendung kopiert Werte aus ComboBoxen in Excel. Allerdings habe ich das Problem, das sie in Excel dann als Text stehen. Da mein Excel Dokument ebenfalls mit Formlen arbeitet und verschiedene Felder zusammenrechnet, muss ich das Dokument öffnen und erst alle als Text gespeicherten Zahlen in eine Zahl umwandeln. Fällt euch eine gute Lösung ein? Ich hätte an eine "Float-ComboBox" gedacht, gibt es ähnliche Komponenten?

Edit: Bitte kommt mir nicht mit "StringToFloat(Excel.Cells[x, y].Value := ComboBoxFloat.Text);", denn wenn man nichts in der ComboBox stehen haben sollte, hängt sich das Programm auf, da '' ja kein Float-Wert ist.

Danke,
Lukas

Luckie 19. Jan 2012 22:06

AW: Float Edit-Feld
 
Zitat:

Zitat von ByTheTime (Beitrag 1146791)
Edit: Bitte kommt mir nicht mit "StringToFloat(Excel.Cells[x, y].Value := ComboBoxFloat.Text);", denn wenn man nichts in der ComboBox stehen haben sollte, hängt sich das Programm auf, da '' ja kein Float-Wert ist.

Dann behandele diesen Fall eben entsprechend.

himitsu 19. Jan 2012 22:18

AW: Float Edit-Feld
 
Tipp: Rate mal, wofür Delphi-Referenz durchsuchenTryStrToFloat erfunden wurde.

Popov 19. Jan 2012 22:18

AW: Float Edit-Feld
 
Zitat:

Zitat von ByTheTime (Beitrag 1146791)
Edit: Bitte kommt mir nicht mit "StringToFloat(Excel.Cells[x, y].Value := ComboBoxFloat.Text);", denn wenn man nichts in der ComboBox stehen haben sollte, hängt sich das Programm auf, da '' ja kein Float-Wert ist.

Bevor du gleich mit Try Except prüfst, ich habe vor einiger Zeit paar Prüfroutinen programmiert. Sie prüfen ob String eine Zahl ist. Ohne Error usw. Vielleicht hilft dir das:

Delphi-Quellcode:
    { Prüft ob String ein Currencywert ist }
function IsValidCurrency(S: String): Boolean;
var
  C: Currency;
begin
  Result := TextToFloat(PChar(S), C, fvCurrency);
end;

    { Prüft ob String ein Extendedwert ist }
function IsValidExtended(S: String): Boolean;
var
  E: Extended;
begin
  Result := TextToFloat(PChar(S), E, fvExtended);
end;
Beispiele:

Delphi-Quellcode:
procedure TForm1.Button1Click(Sender: TObject);
var
  S: String;
begin
  S := '922337203685477,5807';
  if IsValidCurrency(S)
    then ShowMessage(Format('%s ist eine gültige Currency Zahl', [S]))
    else ShowMessage(Format('%s ist keine gültige Currency Zahl', [S]));

  S := '1,1e4932';
  if IsValidExtended(S)
    then ShowMessage(Format('%s ist eine gültige Extended Zahl', [S]))
    else ShowMessage(Format('%s ist keine gültige Extended Zahl', [S]));
end;

ByTheTime 19. Jan 2012 22:30

AW: Float Edit-Feld
 
Danke für die Hilfe,
wie oben schon genannant wollte ich nicht jeden Fall (da es seeehr viele sind) mit try, except behandeln, das wäre sehr aufwendig, das mit dem 'TryStrToFloat' kommt mir gerade recht :)

Sir Rufo 19. Jan 2012 22:51

AW: Float Edit-Feld
 
Es gibt sogar noch ein Delphi-Referenz durchsuchenStrToFloatDef, wo man einen Default-Wert mitgeben kann, der dann benutzt wird, wenn der String nicht umgewandelt werden kann.

ByTheTime 21. Jan 2012 14:39

AW: Float Edit-Feld
 
Ich muss das ganze nochmal aufrollen...
Ich habe versucht, mit "TryStrToFloat" einen String aus einem Edit-Feld in einen Float-Wert umzuwandeln. Leider habe ich den Befehl erst falsch verstanden, und folgendes gemacht:
Delphi-Quellcode:
Excel.Cells[x, y].Value := TryStrToFloat(Edit1.Text);
Dann habe ich erfahren, das TryStrToFloat mir erst als Boolean zurückgibt ob man den String umwandeln kann oder nicht und dann erst den Wert, also (bin mir nicht ganz sicher, wie genau es geht, habe mal meine 2 überlegungen hier):

1. Idee
Delphi-Quellcode:
 var
   b: Boolean;
   f: Float;

 if TryStrToFloat(Edit1.Text, f) then //Wenn der String umgewandelt werden kann...
    Excel.Cells[x, y].Value := f;

mkinzler 21. Jan 2012 14:48

AW: Float Edit-Feld
 
Es gobt auch StrToFloatDef(). Da kann man einen Defaultwert vorgeben, welcher im Fehlerfehl genommen wird.

himitsu 21. Jan 2012 18:32

AW: Float Edit-Feld
 
Die erste Idee ist schon richtig.

TryStrTo... versucht den String umzuwandeln und wenn das ging, dann wird True und der Wert zurückgegeben.
Try wie Versuchen

StrTo...Def wandelt den String immer um und gibt im Fehlerfall den Standardwert zurück.
Def wie Default Value / Standardwert


Es kommt jetzt darauf an, was du willst.
- immer (irgend)eine Zahl schreiben (def)
- wenn möglich eine Zahl schteiben und ansonsten den String (try mit 'nem ELSE und dann als String zuweisen)

ByTheTime 27. Jan 2012 20:08

AW: Float Edit-Feld
 
Sorry, das ich das wieder aufwühle, aber ich kriege es einfach nicht gebacken!!!

Das ist mein Codeschnipsel:
Delphi-Quellcode:
 if TryStrToFloat(TPArray[0].Ort, f) then
    Excel.Cells[9, 4].Value := f;
Was mache ich den falsch... f ist als variable (f: Real;) deklariert...

Sir Rufo 27. Jan 2012 20:13

AW: Float Edit-Feld
 
Warum nimmst du nicht Delphi-Referenz durchsuchenStrToFloatDef?

himitsu 27. Jan 2012 21:52

AW: Float Edit-Feld
 
Zitat:

Zitat von Sir Rufo (Beitrag 1148027)
Warum nimmst du nicht Delphi-Referenz durchsuchenStrToFloatDef?

Kommt ja drauf an, was er erreichen will.

Zitat:

Zitat von ByTheTime (Beitrag 1148026)
Was mache ich den falsch...

Weiß nicht.
Gibt es eine Fehlermeldung und wenn ja welche?
Oder was passiert, bzw. was passiert nicht?

Darlo 28. Jan 2012 13:43

AW: Float Edit-Feld
 
Nur aus dem Kopf, f ist nicht vom Typ Real sondern Double.

himitsu 28. Jan 2012 14:01

AW: Float Edit-Feld
 
Delphi-Referenz durchsuchenTryStrToFloat gibt es jeweils für Single, Double und Extended.
Real ist eine Weiterleitung zu Double. (so wie ein Integer aktuell LongInt entspricht und String entweger AnsiString oder UnicodeString)
Der alte Real-Typ versteckt sich aktuell als Real48.

Sir Rufo 28. Jan 2012 14:06

AW: Float Edit-Feld
 
Zitat:

Zitat von ByTheTime (Beitrag 1147000)
Ich muss das ganze nochmal aufrollen...
Ich habe versucht, mit "TryStrToFloat" einen String aus einem Edit-Feld in einen Float-Wert umzuwandeln. Leider habe ich den Befehl erst falsch verstanden, und folgendes gemacht:
Delphi-Quellcode:
Excel.Cells[x, y].Value := TryStrToFloat(Edit1.Text);

Aus diesem Ansatz leite ich mal ab, dass er mit Delphi-Referenz durchsuchenStrToFloatDef genau das bekommt, was er wollte

himitsu 28. Jan 2012 15:07

AW: Float Edit-Feld
 
Dennoch seh ich das noch nicht so ganz eindeutig geklärt. :oops:

Delphi-Quellcode:
// Setzt es immer als Zahl, egal was im Edit drin steht.
Excel.Cells[x, y].Value := StrToFloatDef(Edit1.Text, 0);

// Setzt es als Zahl, wenn eine Zahl im Edit drin steht und setzt es ansonsten als Text.
if TryStrToFloat(Trim(Edit1.Text), F) then
  Excel.Cells[x, y].Value := F
else
  Excel.Cells[x, y].Value := Edit1.Text;

// Setzt es immer als Zahl und wenn keine Zahl im Edit drin steht, dann knallt es.
Excel.Cells[x, y].Value := StrToFloat(Edit1.Text);

// Setzt es immer als Zahl und wenn keine Zahl im Edit drin steht, dann knallt es, mit einer eigenen Meldung.
if TryStrToFloat(Trim(Edit1.Text), F) then
  Excel.Cells[x, y].Value := F
else
  raise Exception.CreateFmt('"%s" ist kein gültiger Wert.', [Edit1.Text]);

uvm.

ByTheTime 28. Jan 2012 20:14

AW: Float Edit-Feld
 
@Darlo: Ja, sorry, hab den Code nicht aus der IDE kopiert sondern "freihand" geschrieben.

Was ich erreichen möchte ist, das die im Edit-Feld (als Text) stehende Zahl in einen Float-Wert conventieren möchte, damit Excel (wo ich die Werte einfüge) keine Probleme mit seinen Berechnungen hat. ICh möchte nicht in jedem Feld "0" stehen haben, das wird etwas unübersichtlich...

ByTheTime 28. Jan 2012 20:18

AW: Float Edit-Feld
 
Hat sich erledigt!
@Darlo: Danke Darlo, das du das erwähnt hast, ich hatte "f" als "Real" deklariert :S


Alle Zeitangaben in WEZ +1. Es ist jetzt 07:03 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