Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Delphi Problem mit Konvertierung von langen Bitfolgen in Zeichen (https://www.delphipraxis.net/157469-problem-mit-konvertierung-von-langen-bitfolgen-zeichen.html)

Hannes91 12. Jan 2011 19:10

Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Guten Abend,

um mich einmal an (einfachen) Kompressionsalgorithmen zu versuchen, habe ich mir den Huffman-Algorithmus herausgegriffen, der optimal häufig auftretende Zeichen mit kurzen Bitfolgen und seltener auftretende Zeichen mit längeren Bitfolgen versieht.
Da dieser schon gut mit Eingabefeldern auf dem Formular funktionierte, wollte ich ihn für Dateien tauglich machen:
Der zu kodierende Text wird aus einer Datei eingelesen, die Häufigkeiten der Zeichen analysiert, kodiert und soll dann in Bytes verpackt wieder in eine Datei geschieben werden.

Ich schneide also die gesamte Bitfolge in Päckchen von je 8 Bit, z.B. '00111111' als String, woraus ich dann mittels
Delphi-Quellcode:
var
   j, iChr : integer;
   Buffer : string; //z.B. '00111111'
begin
     //
     iChr := 0;
     for j := 1 to 8
     do
       iChr := iChr + StrToInt(Buffer[j]) * Trunc(power(2, 8 - j));
end;
zunächst den Dezimalwert des Zeichens berechne und über
Delphi-Quellcode:
chr(iChr)
das Zeichen erzeuge.

So nun zu dem Problem:
Für z.B.
Delphi-Quellcode:
iChr = 137
liefert
Delphi-Quellcode:
chr(iChr)
merkwürdigerweise
Delphi-Quellcode:
#$0089
, was erstens deutlich größer ist als ein Byte und dann auch nichts mit dem vorgesehenen Promille-Zeichen zu tun hat.
Diese fehlerhaften Zeichenfolgen werden dann in der Datei durch '?' ersetzt, der Rest ist korrekt ausgegeben.

Delphi-Quellcode:
var
   Datei: Textfile;
begin
     AssignFile(Datei, ExtractFilePath(Application.ExeName) + '\' + Dateiname);
     ReWrite(Datei);

     WriteLN(Datei, sOutput);

     CloseFile(Datei);
end;

Habt ihr eine Idee, woran diese "Fehlinterpretation" liegen könnte?

Klaus01 12. Jan 2011 19:20

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Guten Abend,
Hex 0x89 ist nun mal dezimal 137

Aber warum Du mit chr(137) #$0089 herausbekommst?
Ich hätte ein Zeichen erwartet.

Nachtrag:
Warum der Weg über Strings und nicht gleich mit Byte?

Grüße
Klaus

Deep-Sea 12. Jan 2011 19:24

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Du weißt aber schon, das dein Delphi intern mit UTF-16 arbeitet, oder?

Hannes91 12. Jan 2011 19:40

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
@ Klaus01: Danke für den Hinweis, ich habe jetzt den Umweg über String durch ein Array of Byte gestrichen, sodass er natürlich in der Funktion richtige Werte ausspuckt.:thumb:

Jedoch stellt sich da für mich das Problem, wie ich dieses Array of Byte in eine (Text-)Datei speichern kann, da es sich ja nun nicht mehr um einen String mit reellen Zeichen handelt (--> WriteLN()).

Klaus01 12. Jan 2011 19:44

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Hallo,

wenn Du bei den "alten" Routienen bleiben willst..

OutFile : File of Byte

Assign/Reset/Rewrite wie gehabt

Mit write(outFile,DatenByte) wird dann in die Datei geschrieben.

Wenn Du es etwas fortschrittlicher machen willst,
schau Dir mal TFileStream an.

Grüße
Klaus

Hannes91 12. Jan 2011 19:58

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Delphi-Quellcode:
Ì;‰••=>2ÔÆîg닧&¡ÅÒ§÷bïu #2(/4
Das ist doch ganz im Sinne des Problemstellers!

Tausend Dank, v.a. Klaus, funktioniert mit den Bytes.

In einer ruhigen Minute außerhalb der Schulwoche werde ich mit dann mal um den FileStream kümmern (...will ja nicht so ganz den Anschluss verpassen und daher neues Gebiet betreten...).

Schönen Abend noch

Hannes

p80286 13. Jan 2011 12:12

AW: Problem mit Konvertierung von langen Bitfolgen in Zeichen
 
Also bei einem
Delphi-Quellcode:
array of Byte
bietet sich meiner Meinung nach ein
Delphi-Quellcode:
blockwrite
sofort an. Und wenn man die neueren Funktionalitäten nutzen will, ist von dort der Schritt zu
Delphi-Quellcode:
TFilestream
nur noch ein ganz kleiner.

Gruß
K-H


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