AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

"Pos" findet String wegen Einrückung nicht

Ein Thema von Freyr77 · begonnen am 17. Okt 2016 · letzter Beitrag vom 17. Okt 2016
Antwort Antwort
Seite 2 von 2     12   
Freyr77
(Gast)

n/a Beiträge
 
#11

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:24
Sollte ein String 'BlaBlaBla' in einer Zeile (Stringlist[i]) enthalten sein so kommt pos mit einem Wert >0 zurück!
Suchst Du nach 'blaBlaBla' und enthalten ist 'Blablabla' dann kommt 0 zurück!

Einrückungen haben da keinen Einfluß darauf!

Gruß
K-H

P.S.
Was denn nun pos oder .Indexof da gibt es kaum bemerkbare aber wichtige Unterschiede!
Ich habe beides ausprobiert. Am besten funktioniert hat es aber mit "IndexOf".
"Trim" hat übrigens auch nichts geholfen. TrimLeft auch nicht.

Wenn ich es in der Textdatei einrücke, wird es da auch nicht mehr gefunden.
  Mit Zitat antworten Zitat
Freyr77
(Gast)

n/a Beiträge
 
#12

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:27
Ich würde bei einer verschönerten Variante der ersten geposteten Funktion bleiben und Pos benutzen. Das IndexOf funktioniert in dem von die beschriebenen Szenario nicht.
Alles klar, danke. Ich bin jetzt auch zu POS umgestiegen. Allerdings funktioniert keine Trim Variante.
  Mit Zitat antworten Zitat
Jim Carrey
(Gast)

n/a Beiträge
 
#13

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:33
Alles klar, danke. Ich bin jetzt auch zu POS umgestiegen. Allerdings funktioniert keine Trim Variante.
Zeig doch mal deine Varianten.
  Mit Zitat antworten Zitat
Benutzerbild von Jasocul
Jasocul

Registriert seit: 22. Sep 2004
Ort: Delmenhorst
1.354 Beiträge
 
Delphi 11 Alexandria
 
#14

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:46
Delphi-Quellcode:
var
   sList: TStringList;
   Index: integer;

begin
   sList := TStringList.Create;

   Result := -1;
   sList := TStringList.Create;
   sList.LoadFromFile(FileName);
// for Index := 0 to sList.Count do // Falsch
   for Index := 0 to sList.Count-1 do
     if Pos(SearchText, sList.Strings[Index]) > 0 then
     begin
       Result := Index;
       sList.Free;
       Exit;
     end
     else
       ShowMessage('Einstiegspunkt wurde nicht gefunden.');
   sList.Free;
end;
Also, wenn der Suchbegriff erst in der zweiten Zeile steht, klappt das schon nicht mehr.
Deswegen bist du auch der Meinung, dass IndexOf besser funktioniert. Aber dort bekommst du Probleme, wenn du mit Einrückungen (führenden Leerzeichen) arbeitest.

Meine Prüfung sähe so aus, wenn ich deinen Stil beibehalte:
Delphi-Quellcode:
var
   sList: TStringList;
   Index: integer;

begin
   sList := TStringList.Create;

   Result := -1;
   sList := TStringList.Create;
   sList.LoadFromFile(FileName);
   for Index := 0 to sList.Count-1 do
     if Pos(SearchText, sList.Strings[Index]) > 0 then
     begin
       Result := Index;
       sList.Free;
       //Exit; Das ist natürlich falsch
       Break;
   sList.Free;
   if Result = -1 then
     ShowMessage('Einstiegspunkt wurde nicht gefunden.');
end;
Der Unterschied ist, dass ich nicht in der Schleife prüfe, ob der Einstiegspunkt falsch ist, sondern nach der Schleife prüfe, ob ein gültiges Ergebnis vorliegt.
Peter

Geändert von Jasocul (17. Okt 2016 um 14:58 Uhr) Grund: Blöden Fehler korrigiert (Break <> Exit)
  Mit Zitat antworten Zitat
Freyr77
(Gast)

n/a Beiträge
 
#15

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:54
Delphi-Quellcode:
var
   sList: TStringList;
   Index: integer;

begin
   sList := TStringList.Create;

   Result := -1;
   sList := TStringList.Create;
   sList.LoadFromFile(FileName);
// for Index := 0 to sList.Count do // Falsch
   for Index := 0 to sList.Count-1 do
     if Pos(SearchText, sList.Strings[Index]) > 0 then
     begin
       Result := Index;
       sList.Free;
       Exit;
     end
     else
       ShowMessage('Einstiegspunkt wurde nicht gefunden.');
   sList.Free;
end;
Also, wenn der Suchbegriff erst in der zweiten Zeile steht, klappt das schon nicht mehr.
Deswegen bist du auch der Meinung, dass IndexOf besser funktioniert. Aber dort bekommst du Probleme, wenn du mit Einrückungen (führenden Leerzeichen) arbeitest.

Meine Prüfung sähe so aus, wenn ich deinen Stil beibehalte:
Delphi-Quellcode:
var
   sList: TStringList;
   Index: integer;

begin
   sList := TStringList.Create;

   Result := -1;
   sList := TStringList.Create;
   sList.LoadFromFile(FileName);
   for Index := 0 to sList.Count-1 do
     if Pos(SearchText, sList.Strings[Index]) > 0 then
     begin
       Result := Index;
       sList.Free;
       Exit;
   sList.Free;
   if Result = -1 then
     ShowMessage('Einstiegspunkt wurde nicht gefunden.');
end;
Der Unterschied ist, dass ich nicht in der Schleife prüfe, ob der Einstiegspunkt falsch ist, sondern nach der Schleife prüfe, ob ein gültiges Ergebnis vorliegt.
Genau auf diesen blöden Fehler von mir bin ich gerade auch gestoßen. Jetzt funktioniert es.

Sieht bei mir jetzt so aus:

Delphi-Quellcode:
var
  sList: TStringList;
  Index: integer;

begin
  sList := TStringList.Create;

    Result := -1;
    sList := TStringList.Create;
    sList.LoadFromFile(FileName);
    for Index := 0 to sList.Count do
    begin
      if Pos(SearchText, sList.Strings[Index]) <> 0 then
      begin
        Result := Index;
        sList.Free;
        Exit;
      end
    end;

      ShowMessage('Einstiegspunkt wurde nicht gefunden.');
      sList.Free;
end;
Danke an alle.
  Mit Zitat antworten Zitat
Benutzerbild von Jasocul
Jasocul

Registriert seit: 22. Sep 2004
Ort: Delmenhorst
1.354 Beiträge
 
Delphi 11 Alexandria
 
#16

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 14:56
Ändere das bitte noch so:
Delphi-Quellcode:
var
   sList: TStringList;
   Index: integer;

begin
   sList := TStringList.Create;

     Result := -1;
     sList := TStringList.Create;
     sList.LoadFromFile(FileName);
// for Index := 0 to sList.Count do Das ist auch falsch
     for Index := 0 to sList.Count-1 do
     begin
       if Pos(SearchText, sList.Strings[Index]) <> 0 then
       begin
         Result := Index;
         sList.Free;
         Break; // Nicht Exit!
       end
     end;

       ShowMessage('Einstiegspunkt wurde nicht gefunden.');
       sList.Free;
end;
Peter

Geändert von Jasocul (17. Okt 2016 um 14:59 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von uligerhardt
uligerhardt

Registriert seit: 19. Aug 2004
Ort: Hof/Saale
1.746 Beiträge
 
Delphi 2007 Professional
 
#17

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 16:44
...aber bitte mit try-finally wie in Post 2!
Uli Gerhardt
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.736 Beiträge
 
Delphi 6 Enterprise
 
#18

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 17:05
Irgendwie kommt mir das aber alles unsauber vor. Wieso wird die Stringlist 2x erzeugt und frei gegeben, das passt doch alles nicht.

Delphi-Quellcode:
var
  sList: TStringList;
  Index: integer;
begin
  Result := -1;
  sList := TStringList.Create;
  try
    sList.LoadFromFile(FileName);
    for Index := 0 to sList.Count-1 do
      begin
       if Pos(SearchText, sList.Strings[Index]) <> 0 then
         begin
           Result := Index;
           Break;
         end
       end;

    //Das Folgende hab ich mal drin gelassen, aber eigentlich
    //gehört das z.B. in die aufrufende Prozedur verlagert
    if Result=-1 then
      ShowMessage('Einstiegspunkt wurde nicht gefunden.');

  finally
    sList.Free;
  end;
end;
Ralph
  Mit Zitat antworten Zitat
Whookie

Registriert seit: 3. Mai 2006
Ort: Graz
445 Beiträge
 
Delphi 10.3 Rio
 
#19

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 17:08
Da ist eindeutig ein TStringList.Create/.Free zuviel drin!

So müsste das aussehen (nicht getestet):
Delphi-Quellcode:
begin
  Result := -1;
  sList := TStringList.Create;
  try
    LTst := LowerCase(Trim(SearchText));
    for i := 0 to sList.Count-1 do
    begin
      if Pos(LTst, LowerCase(sList[i])) > 0 then
      begin
        Result := i;
        Break;
      end;
    end;
  finally
    sList.Free;
  end;
  //
  If Result < 0 then
    ShowMessage('Einstiegspunkt wurde nicht gefunden.');
end;
Whookie

Software isn't released ... it is allowed to escape!

Geändert von Whookie (17. Okt 2016 um 19:39 Uhr) Grund: -= (du sollst keinen ungetesteten code eingebn.dusollst keinen....
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.033 Beiträge
 
Delphi 12 Athens
 
#20

AW: "Pos" findet String wegen Einrückung nicht

  Alt 17. Okt 2016, 18:03
PS: Delphi-Referenz durchsuchenPos gibt 'ne Position zurück, aber was du eigentlich machen willst ist Delphi-Referenz durchsuchenContainsStr, oder eventuell auch mal Delphi-Referenz durchsuchenContainsText.


Zitat:
 if Pos(LTst, LowerCase(sList[i])) >= 0 then
Und Pos ist immer >= 0.

0, wenn nichts gefunden,
und 1, wenn doch, da 1-basierender Index.

Bei IndexOf isses natürlich anders, denn
-1, wenn nichts gefunden,
und 0, wenn doch, da 0-basierender Index.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (17. Okt 2016 um 18:06 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:26 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