Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi calfield nimmt daten falsch an (https://www.delphipraxis.net/13559-calfield-nimmt-daten-falsch.html)

coolstranger 21. Dez 2003 11:29


calfield nimmt daten falsch an
 
hallo!
ich habe ein problem. ich spiele golf und wollte mir eine interaktive scorecard über 9 löcher machen! hat auch geklappt. jetzt wollte ich alle daten von den einzelnen "löchern" an eine "gesamt" spalte senden, in der delphi per calcfield alles zusammenrechnet. der code sieht so aus:

Code:
procedure TForm1.ingoCalcFields(DataSet: TDataSet);
begin
 ingoGesamt.Value := ingoL1.Value + ingoL2.Value + ingoL3.Value + ingoL4.Value + ingoL5.Value + ingoL6.Value + ingoL7.Value + ingoL8.Value + ingoL9.Value;
end;
wenn ich jetzt zahlen eingebe rechnet er nichts zusammen er sagt in der spalte gesamt, wenn ich in L1 und L2 "5" eingebe 55. warum ist bei delphi 5+5=55? und nicht 5+5=10? was habe ich falsch gemacht

Ratte 21. Dez 2003 12:41

Re: calfield nimmt daten falsch an
 
Hallo,

ich vermute das die beiden Zahlen als Strings behandelt werden und aneinandergehängt werden.
Probier es mal so:
Delphi-Quellcode:
ingoGesamt.Value :=inttostr(strtoint(ingoL1.Value) + strtoint(ingoL2.Value) + strtoint(ingoL3.Value) + strtoint(ingoL4.Value) + strtoint(ingoL5.Value) + strtoint(ingoL6.Value) + strtoint(ingoL7.Value) + strtoint(ingoL8.Value) + strtoint(ingoL9.Value));
Ratte

coolstranger 21. Dez 2003 16:17

Re: calfield nimmt daten falsch an
 
cool es funktioniert aber seitdem ich es so gemacht habe kommt folgender alarmtext beim starten des programmes:
Code:
Exception EConvertError in module Project1.exe at 000082FA.
'' is not a valid integer value.
was ist das? wie kann ich das beheben?

achso während des startens (F9) mit delphi kommt folgendes:
Code:
Project Project1.exe raised exception class EConvertError with Message '' is not an valid integer value.

coolstranger 21. Dez 2003 17:34

Re: calfield nimmt daten falsch an
 
ich glaube ich habe den fehler gefunden!
ich habe nochmal diese berechnungsformel entfernt jetzt geht es wieder? warum war es mit dieser formel so. gibt es nur die möglichkeit inttostr und strtoint? vielleicht sind meine eingaben gar keine integer oder strings. was ist da der unterschied?

Hilfe ich kriege kopfschmerzen!!! :wall: :wall: :wall: :wall:

Ratte 25. Dez 2003 15:07

Re: calfield nimmt daten falsch an
 
Hi,

probier stattdessen mal:
Delphi-Quellcode:
IF (ingoL1.Value='') OR (ingoL2.Value='') OR (ingoL3.Value='') OR (ingoL4.Value='') OR ingoL5.Value='') OR (ingoL6.Value='') OR (ingoL7.Value='') OR (ingoL8.Value='') OR (ingoL9.Value='') THEN
ingoGesamt.Value :=inttostr(strtoint(ingoL1.Value) + strtoint(ingoL2.Value) + strtoint(ingoL3.Value) + strtoint(ingoL4.Value) + strtoint(ingoL5.Value) + strtoint(ingoL6.Value) + strtoint(ingoL7.Value) + strtoint(ingoL8.Value) + strtoint(ingoL9.Value));
Ratte

Niels 26. Dez 2003 12:06

Re: calfield nimmt daten falsch an
 
Moin!

@Ratte:
Deine jetzige Variante startet nur die Berechnung, wenn ein Fehler in der Berechnung auftreten würde. Ich glaub du meinst eher:

Delphi-Quellcode:
IF [u]not[/u] ((ingoL1.Value='') OR (ingoL2.Value='') OR (ingoL3.Value='') OR (ingoL4.Value='') OR ingoL5.Value='') OR (ingoL6.Value='') OR (ingoL7.Value='') OR (ingoL8.Value='') OR (ingoL9.Value='')) THEN
ingoGesamt.Value :=inttostr(strtoint(ingoL1.Value) + strtoint(ingoL2.Value) + strtoint(ingoL3.Value) + strtoint(ingoL4.Value) + strtoint(ingoL5.Value) + strtoint(ingoL6.Value) + strtoint(ingoL7.Value) + strtoint(ingoL8.Value) + strtoint(ingoL9.Value));
Nun würde aber, wenn ein Wert leer ist gar nicht erst eine Berechnung angestellt werden.

@Coolstranger:
Ob deine Eingaben Strings oder Integers sind solltest du wohl als einziger von uns wissen. Schließlich hast du die Variablen irgendwo definiert. Ich geh aber davon aus, dass es Strings sind, da du ja keine Fehlermeldung bekommst, wenn du etwas mit IntToStr drauf zuweist.

Du musst das mit IntToStr / StrToInt machen, da du ja den numerischen Wert zweier Strings addieren willst.
Ich würde das Ganze folgendermaßen machen. Du schreibst die ne eigene Prozedur, die dir den String in einen Integer umwandelt und dabei prüft, ob der String evtl '' ist.

Delphi-Quellcode:
function ToInt(Source: String): Integer;
begin
  if Source = '' then
    result := 0
  else
    result := StrToInt(Source);
end;
Nun muss deine Berechnungsformel so aussehen:

Delphi-Quellcode:
ingoGesamt.Value := IntToStr(ToInt(ingoL1.Value) + ToInt(ingoL2.Value) + ToInt(ingoL3.Value) + ToInt(ingoL4.Value) + ToInt(ingoL5.Value) + ToInt(ingoL6.Value) + ToInt(ingoL7.Value) + ToInt(ingoL8.Value) + ToInt(ingoL9.Value));
Das ist meiner Meinung nach die beste Möglichkeit

MfG Niels


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