![]() |
AW: Zeilen in einem String zählen
Zitat:
Delphi-Quellcode:
nach dem ersten Inc(p) steht doch der Stringzeiger bereits auf dem ersten Zeichen der neuen Zeile.
if (P + 1)^ = #10 then
Inc(P); Inc(P); {<<<} /hier!!! |
AW: Zeilen in einem String zählen
Das zweite Inc(P) gehört zur #13 und das erste zur #10. (darum nochmal die Drehung im zweiten Code)
Delphi-Quellcode:
Letzteres ist also die direkte/ursprüngliche Funktionsweise und beim ursprünglichen Code wurde das alles in einen etwas kürzeren Code optimiert.
while P^ <> #0 do
if P^ = #13 then begin Inc(Result); if (P + 1)^ = #10 then // nächstes Zeichen Inc(P); // #10 Inc(P); // #13 end else if P^ = #10 then begin Inc(Result); Inc(P); // #10 end else Inc(P); // Rest while P^ <> #0 do if P^ = #13 then begin Inc(Result); Inc(P); // #13 if P^ = #10 then Inc(P); // #10 end else if P^ = #10 then begin Inc(Result); Inc(P); // #10 end else Inc(P); // Rest Dieses Erste entspricht von der Funktion dem Urspungscode, nur daß ursprünglich eben die dreifachen Inc(P) zu Einem zusammengefast und aus den IFs rausgeholt waren. Früher war #13#10 der Zeilenumbruch (kennt man vorallem von den Druckern ... CR/CarriageReturn/#13 zurück zum Zeilenanfang + LF/LineFeed/#10 zur nächsten Zeile) Windows macht das standardmäßig immernoch so. Linux wollte sparen, drum nutzen die standardmäßig nur noch #10, wo implizit das Carriage Return mit enthalten ist. Macintosh kochte sein eigenes Süppchen und dachte sich #13 wäre auch ein guter Zeilenwechsel, obwohl das syntaktisch nun überhaupt nicht stimmt. Windows selber unterstützt standardmäßig alles (vorallem #13#10 und #10), aber z.B. im neuen RichEdit-Control v3 hat man totalen Mist gebaut und dort wird das #13 als Zeilenumbruch verwendet (keine Ahnung warum). #10#13 währe teschnich gesehn auch ein Zeilenumbruch, aber dieses wird als #10 und #13 angesehn, also zwei Zeilenumbrüche. Vermutlich weil es einfacher zu implementieren war, bzw. bei der implementierung keiner dran gedacht hat (währe aber auch nur ein IF+INC mehr). |
AW: Zeilen in einem String zählen
@schöni:
Zitat:
|
AW: Zeilen in einem String zählen
Ganz einfach einfach!
Entweder ist es #10 oder #13 oder #13#10, aber nie gemischt, also einfach einfach machen. Und noch was, auch Str := '' ist eine Zeile!
Delphi-Quellcode:
function CRLFCount(Str: String): Integer;
var cl: Char; begin Result := 1; cl := #10; if Pos(cl, Str) = 0 then cl := #13; while Pos(cl, Str) > 0 do begin Inc(Result); Delete(Str, 1, Pos(cl, Str) + 1); end; end; procedure TForm1.Button1Click(Sender: TObject); var s: String; begin s := 'aaa' + #13#10 + 'aaa' + #13#10 + 'aaa' + #13#10 + 'aaa'; ShowMessage(IntToStr(CRLFCount(s))) end; |
AW: Zeilen in einem String zählen
Zitat:
|
AW: Zeilen in einem String zählen
Eine kleine Änderung:
Delphi-Quellcode:
Gruß
function CountLines(const s: string): integer;
var PrevCR: Boolean; //Previous Carriage Return i: integer; begin Result := 0; PrevCR := false; for i := 1 to Length(s) do begin case s[i] of #13: Inc(Result); #10: if not PrevCR then Inc(Result); end; PrevCR := s[i]=#13; end; end; K-H Das mit dem CarriageReturn und Linefeed sollte man ganz wörtlich nehmen. mit #13 #10 #10 #10 kann man auf der Konsole, und bei den meisten Druckern 2 Leerzeilen erzeugen. Wenn das Gerät sich auf die Interpretation der ASCII-Zeichen einläßt! |
AW: Zeilen in einem String zählen
Danke, mich hat die doppelte Zuweisung auch gestört :thumb:
|
AW: Zeilen in einem String zählen
Zitat:
Zitat:
Aber OK, dann müßte die Funktion aber vorher schauen welcher Zeilenumbruch verwendet wurde und dann eine entsprechende Such-/Zählfunktion ausführen, oder man sagt der Funktion was vermutlich verwendet wurde oder man bastelt sich mehrere Funktion (oder nur die Eine grade nötige) und ruft jeweils die vermutlich Entsprechende auf. Oder die Funktion kennt gleich alles und ihr ist es egal, was man reingibt. :angle2: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:25 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