![]() |
Modulo-10 Prüfsumme eines Strings berechnen
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo!
Ich möchte gerne eine Prüfsummenberechnung implementieren. Habe ich aber noch nie gemacht. Alles was ich habe ist die im Anhang gezeigte Formel und davon das MOD 10. Soweit ich als Schwachmathematiker das beurteilen kann, gibt es da keine Gewichtung sondern lediglich die Quersumme der einzelnen ASCII-Codes MOD 10. Soweit richtig? Zweite Frage: Wie verfahre ich mit Non-ASCII-Zeichen? Ordinalposition des Widechar oder die Bytes einzeln? Der zugrunde liegende Standard stammt noch aus der Vor-Unicode-Ära bzw. dem letzten Jahrtausend. Grüße Cody |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Analog zu
![]()
Delphi-Quellcode:
(nur hingedaddelt und ungetestet)
function Modulo10FromString(s : String) : Integer;
var i : Integer; begin Result := 0; for i := 1 to Length(s) do begin case i mod 2 of 0 : Result := Result + (Ord(s[i]) * 3); 1 : Result := Result + Ord(s[i]); else // Upps, das geht doch garnicht ;-) end; end; Result := Result Mod 10; end; Ob ASCII oder nicht, sollte eigentlich egal sein, es geht ja um alle Zeichen im String und nicht nur um die Zeichen im String, die eine bestimmte Anforderung erfüllen. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Zitat:
Delphi-Quellcode:
function Checksum(const AStr: string): Byte;
var A: AnsiString; C: AnsiChar; I: Integer; begin A:= AnsiString(AStr); I := 0; for C in A do begin I := I + Ord(C); end; Result := (I mod 10); end; |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Ich schrieb analog zu
![]() Zitat:
Welche man wählt ist eigentlich egal, solange man sich dann an die gewählte Version hält und nicht (bei der Kommunikation mit anderen Systemen) quasi so 'ne Art "Mischkalkulation" bekommt. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Zitat:
Auf der von dir verlinkten Seite war ich auch bevor ich hier gefragt habe. Die Prüfsummenberechnung bekomme ich ja hin, mit der Formel war ich mir hingegen gar nicht sicher. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Zitat:
Pruefsumme('abc') = Pruefsumme('bac') Alles ist andere als ideal. Was Non-ASCII angeht, so kann dir das keiner von uns sagen sondern nur derjenige, der dir die Vorgabe gemacht hat. Ohne weitere Angaben würde ich bei Non-ASCII eine Exception werfen (und dabei auf denjenigen zielen, der die Vorgabe gemacht hat). |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Also fragen wir mal so:
Wofür brauchst Du das? Dann kann man eventuell bei der Suche / Implementierung der erforderlichen Variante helfen. Die verlinkte Seite beschreibt halt den Algorithmus für eine bestimmte Implementierung für einen konkreten Sachverhalt. Weitere Info: ![]() ![]() ![]() und vieles mehr: ![]() Ohne konkrete Aufgabenstellung sehe ich kaum 'ne Möglichkeit, den von Dir konkret benötigten Algorithmus zu finden. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Zitat:
Das mit den möglichen Kollisionen scheint damals wohl noch niemanden interessiert zu haben. Ich glaube da ging es auch weniger um Manipulationsfestigkeit als die Erkennung von Übertragungsfehlern. Ob Rückwärtskompatibilität gefragt ist oder nicht muss ich intern klären. Wenn nicht wäre dein Hinweis richtig und sinnvoll anzuwenden. Zitat:
Zitat:
Die Daten sind zeilenorientierte Klartextdaten. Je Zeile wäre eine Checksumme zu schreiben und zwischen Daten und Zeilenumbruch zu setzen. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Hast Du schon eine "fertige" Datei (von Anno 1995 oder so), die man als Vorlage nutzen könnte, und durch umgekehrtes "studieren geht über probieren" ;-) auseinander nehmen könnte, um den Algorithmus daraus zu rekonstruieren?
Nach Deiner Beschreibung würd' ich aber nicht drauf achten, ob nun Unicode oder nicht, sondern zeichenweise vorgehen. Dann müsste bei 'nem aus DOS-Zeiten übernommen String das gleiche Ergebnis rauskommen, wie bei einer neu eingegebene Zeichenfolge in Unicode. Unter DOS war A = 65 unter Unicode ist es = 0065 Wenn man zeichenweise vorgeht, bleibt der Wert von A erhalten. Teilt man nun die 0065 in 00 und 65 auf kommt ohne Gewichtung das Gleiche heraus, mit Gewichtung aber nicht mehr. Für mich erscheint es sinnvoller zeichenweise vorzugehen, unabhängig davon, in wievielen Bits und Bytes ein Zeichen hardware-/softwareseitig nun abgelegt wird. |
AW: Modulo-10 Prüfsumme eines Strings berechnen
Das ist eine Sache, wo man die Hand heben sollte + laut "Problem" rufen sollte. Die Formel (so wie damals) zu implementieren ist ja nicht schwer + ein paar Sonderfälle abzufangen, auch nicht. ABER: Da können jetzt andere Daten als damals kommen. Und so etwas betrifft in der Regel nicht nur eine Stelle, sondern viele und ist ein Indiz für ein richtig gutes Problem.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 20:19 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz