![]() |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Delphi-Quellcode:
Memo2.Text := WrapText(StringReplace(Memo1.Text,#13#10,' ',[rfReplaceAll])
Ersetzt er damit nicht alle Leerzeichen mit einem Zeilenumbruch? @Lukie: Die Einrückung habe ich im "Progrämmchen" erst mal weg gelassen, um meinen Fehler zu finden ;-) So, ich habe nun nach Perlsau's Tipp meinen Quelltext angepasst:
Delphi-Quellcode:
Nun brummt das Programm bei der Einstellung nicht mehr auf.
while textlaenge > textbreite do
begin zwPos := Pos(' ', kopText); if zwPos > 0 then begin zeilenlaenge := zeilenlaenge + zwPos; if zeilenlaenge > textbreite then begin ausgabetext := ausgabetext + Copy(orgText, 1, zlPos); ausgabetext := ausgabetext + zu; Delete(orgText, 1, zlPos); textlaenge := textlaenge - zlPos; zlPos := 0; zwPos := 0; zeilenlaenge := 0; end else begin Break; end; zlPos := zlPos + zwPos; Delete(kopText, 1, zwPos); end; end; LG Micha |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Nein,
![]()
Delphi-Quellcode:
StringReplace ersetzt im String S die Vorkommen des in OldPattern angegebenen Teilstrings durch den in NewPattern angegebenen Teilstring.
function StringReplace(const S, OldPattern, NewPattern: string; Flags: TReplaceFlags): string;
Was bedeutet "aufbrummen" in deinem Kontext? Bei mir hat da außer mir selbst nichts gebrummt. Zu deiner Programm-Änderung: zwPos = 0, wenn der Suchstring nicht gefunden wurde. Dann sind aber noch nicht zwangsläufig alle Wörter aus dem ersten Memo ins zweite übertragen, weil das ja innerhalb des neuen Begin-End-Blocks geschieht und dieser bei zwPos = 0 nicht mehr durchlaufen wird. Daher solltest du das nach Abarbeiten der While-Schleife noch überprüfen. Zum Fehlverhalten kam es, wenn ein Wort länger als die eingestellte Zeilenbreite ist, da kannst du verständlicherweise kein Leerzeichen finden. Es muß sich dabei nicht zwangsläufig um ein derart langes Wort handeln, denn auch falsche Zeichensetzung, z.B. das fehlende Leerzeichen nach Punkt oder Komme machen daraus programmtechnisch ein Wort. |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Hallo Perlsau,
vielen Dank für Die Info zu "StringReplace" - Ich hab noch nicht nachgelesen was es genau bedeutet, nur eine Vermutung geäußert (Notiz an mich: Erst lesen, dann vermuten...) Vor der Abfrage, ob "zwPos > 0" ist, kam die Meldung "Keine Rückmeldung", nun erscheint diese nicht mehr - Dies meinte ich ;-) Danke für Deinen weiteren Hinweis, ich denke gerade drüber nach. LG Micha |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Zitat:
Zitat:
|
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Zitat:
Hallo HolgerX, igit ist das einfach. Nun habe ich mir mal "WrapText" angesehen und auch Deinen Text verstanden. Vielen Dank allen, die mir auf die Sprünge geholfen haben. Wünsche Euch eine schöne Woche. LG Micha :-) Hallo Perlsau, Zitat:
Danke für Deine Hilfe, LG Micha :-) |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Es kommt eben auf die Definition des Wortbegriffes an. Wenn du ein Wort so definierst, daß am Ende jeses Wortes ein Leerzeichen stehen muß, findest du natürlich nicht alle Worte, weil am Ende eines Satzes – zumindest im Deutschen – niemals ein Leerzeichen nach einem Wort steht, sondern gewöhnlich ein Punkt. Du willst aber gar nicht nach Worten suchen, sondern nach sinnvollen Stellen für den Textumbruch. Da ist das Leerzeichen natürlich vollkommen richtig gewählt – vorausgesetzt, daß derjenige, der den Text erfaßt, also getippt hat, sich an die deutsche Zeichensetzung hielt und auf jedes Satzzeichen ein Leerzeichen folgen ließ. Wenn der Text dagegen so aussieht:
Es kommt eben auf die Definition des Wortbegriffes an.Wenn du ein Wort so definierst,daß am Ende jeses Wortes ein Leerzeichen stehen muß,findest du natürlich nicht alle Worte,weil am Ende eines Satzes–zumindest im Deutschen–niemals ein Leerzeichen nach einem Wort steht,sondern gewöhnlich ein Punkt.Du willst aber gar nicht nach Worten suchen,sondern nach sinnvollen Stellen für den Textumbruch.Da ist das Leerzeichen natürlich vollkommen richtig gewählt–vorausgesetzt,daß derjenige,der den Text erfaßt,also getippt hat,sich an die deutsche Zeichensetzung hielt und auf jedes Satzzeichen ein Leerzeichen folgen ließ. In diesem Fall werden nicht alle Worte korrekt gefunden. Steht dann am Schluß des Textes noch ein Wort, das länger ist als die gewählte Textbreite, z.B. Rindfleischetikettierungsüberwachungsaufgabenübert ragungsgesetz, Grundstücksverkehrsgenehmigungszuständigkeitsübert ragungsverordnung, Verkehrsinfrastrukturfinanzierungsgesellschaftsges etz oder Vermögenszuordnungszuständigkeitsübertragungsveror dnung, wird dort auch kein Leerzeichen gefunden und das Wort wird nicht in das zweite Memo übernommen. Am besten scheint mir – so mache zumindest ich das immer bei komplexeren Aufgaben –, du stellst dir das Problem beim Debuggen bildlich vor oder malst es sogar erstmal genau auf, mit allen Eventualitäten. Bei Debuggen stelle ich mir bei jedem Programmschritt vor, wie die geänderte Variable danach auszusehen hat und schaue dann in den überwachten Ausdrücken nach, ob das erwartete Resultat auch eingetreten ist. Es ist ja letztlich die Aufgabe des Programmierers, nahezu alle denkbaren Eventualitäten abzudecken, um eine nahezu fehlerfreie Software zu garantieren. ![]() Leider zerstückelt der Foren-Editor die langen Wörter irgendwie ... |
AW: Erhalte vom Programm "Keine Rückmeldung" - Speicherüberlauf?
Um die Probleme etwas zu minimieren kannst Du auch den Aufruf von WrapText erweitern:
Delphi-Quellcode:
Oder Du gest hin und normalisierst den Text erstmal (z.B. Leerzeichen nach Satzzeichen einfügen..).
Memo2.Text := WrapText(StringReplace(Memo1.Text,#13#10,' ',[rfReplaceAll])
,sLineBreak , [' ','.',',','!','?',#9] // Hier alle Zeichen einfügen an denen umgebrochen werden kann ,StrToInt(edit1.Text)); Jedoch ist das mit WrapText einfacher ;) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:42 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