Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Algorithmen, Datenstrukturen und Klassendesign (https://www.delphipraxis.net/78-algorithmen-datenstrukturen-und-klassendesign/)
-   -   Kombinieren von Repeat- mit For-Schleifen (https://www.delphipraxis.net/167605-kombinieren-von-repeat-mit-schleifen.html)

Schüler 8. Apr 2012 21:53


Kombinieren von Repeat- mit For-Schleifen
 
Hallo, liebe Delphianer!
Ich versuche gerade eine Suche in einem Stringgrid zu starten, dass ist auch kein Problem, aber sobald er den Suchbegriff findet und eine Message anzeigt, hängt er sich auf. Ich vermute es liegt daran das ich keine Abbruchbedingung festgelegt habe ich weiß jetzt im Moment aber auch nicht wie ich das mache! Eine andere Idee von mir wäre, eine Repeat-Until mit einer For-To-Schleife zu kombinieren, aber an der Umsetzung mangeld es noch!
Hier mein Such-Algorithmus:
Delphi-Quellcode:
-------------------------------------------------------------
procedure TFrKundenliste.cmdSucheClick(Sender: TObject);
Var i,k : Integer;
    Suchbegriff : String;
begin
   for i:=0 to Kundenliste.colcount-1 do
   for k:=1 to Kundenliste.rowcount-1 do
   if Kundenliste.Cells[k,i]=Suchbegriff then
   begin
   ShowMessage('Gefunden!');
   end
   else ShowMessage('Pech gehabt!');
end;
--------------------------------------------------------------
Hilfe!:roll:

jaenicke 8. Apr 2012 22:50

AW: Kombinieren von Repeat- mit For-Schleifen
 
Zitat:

Zitat von Schüler (Beitrag 1160795)
dass ist auch kein Problem, aber sobald er den Suchbegriff findet und eine Message anzeigt, hängt er sich auf.

Was meinst du mit aufhängen?

Die Schleife läuft in dem Moment natürlich nicht weiter, da das Programm noch in der Showmessage-Funktion ist. Aber danach sollte die Schleife normal weitergehen. Deshalb ist mir nicht ganz klar was du erreichen willst. Wenn die Schleife weiterlaufen soll, darfst du sie nicht mit einer Anzeigebox blockieren. Dann musst du den Fund z.B. in ein TMemo oder eine andere Komponente schreiben.

Amateurprofi 8. Apr 2012 22:51

AW: Kombinieren von Repeat- mit For-Schleifen
 
1) auf cells wird mit cells[col,row] zugegriffen, du greifst mit cells[row,col] darauf zu. Wenn das Grid nicht zufällig quadratisch ist, müßtest du eigentlich eine Exception kriegen.
2) Suchbegriff ist leer, d.h. du müßtest für jede leere Zelle eine Message "Gefunden" erhalten und für jede nicht leere Zelle eine Message "Pech gehabt".
Ich unterstelle mal du willst nach der Message "Gefunden" die Prozedur verlassen und willst die Message "Pech gehabt" nur dann erhalten, wenn der Suchbegriff im Grid nicht gefunden wurde.
Das könntest du z.B. so realisieren :
Delphi-Quellcode:
   for i:=0 to Kundenliste.colcount-1 do
      for k:=1 to Kundenliste.rowcount-1 do
         if Kundenliste.Cells[i,k]=Suchbegriff then begin
            ShowMessage('Gefunden!');
            exit;
         end;
   ShowMessage('Pech gehabt!');
Du solltest aber auch dafür sorgen, daß Suchbegriff nicht leer ist

silver-moon-2000 8. Apr 2012 22:53

AW: Kombinieren von Repeat- mit For-Schleifen
 
Wenn es Dir darauf ankommt, ob der Suchbegriff überhaupt, und die genau Anzahl der Vorkommnisse uninteressant ist,
müssen ja nicht alle Zellen untersucht werden. Jedenfalls verstehe ich Dein Anliegen so.

In diesem Fall wäre eine Möglichkeit, die Schleifen zu verlassen, sobald der Suchbegriff einmal gefunden wurde.
Eine Möglichkeit, wäre in diesem Fall (zwei for Schleifen hintereinander) wohl die Einführung einer Variable.

Delphi-Quellcode:
procedure TFrKundenliste.cmdSucheClick(Sender: TObject);
Var i,k : Integer;
    Suchbegriff : String; //<----- wo wird diese Variable mit Leben gefüllt?
    gefunden : Boolean;//<-------- Variable zur Erkennung, ob Suchbegriff gefunden wurde
begin
  gefunden := False; //<------ Am Anfang auf False setzen, also nichts gefunden
  for i:=0 to Kundenliste.colcount-1 do
  begin
    for k:=1 to Kundenliste.rowcount-1 do
    begin
      if Kundenliste.Cells[i, k]=Suchbegriff then //<-- Reihenfolge getauscht
      begin
        ShowMessage('Gefunden!');
        gefunden := True; //<-- Die Suche hat einen Treffer ergeben
        Break; //<-- Break verlässt die for-Schleife
      end
    end;
//wenn die innere for Schleife verlassen wurde, sind wir aber immer noch in der äußeren
//die wir ebenfalls verlassen müssen. Zur Erkennung, wann wir die Schleife verlassen sollen
//dient in diesem Fall die Variable gefunden"
    if gefunden then
      Break; //verlässt auch die äußere Schleife
  end;
//wenn man hier ankommt, ist folgendes eingetreten:
//- Entweder, der Suchbegriff wurde gefunden (gefunden = True) und die Schleife vorzeitig verlassen
//- oder die Suche hat keinen Treffer ergeben (gefunden = False) und alle Zellen wurden durchsucht
  if not gefunden then //Ausgabe nur einmal ganz am Schluß, dass der Suchbegriff nicht auftaucht
    ShowMessage('Pech gehabt');
end;
Es gibt mit Sicherheit schönere / einfachere Varianten als die, die ich hier vorgestellt habe

Eigentlich dürfte Dein Program sich nicht aufhängen.
[edit] Ich sehe gerade, Du hast Col und Row in
Delphi-Quellcode:
Cells[k,i]
vertauscht, das sollte mEn
Delphi-Quellcode:
Cells[i, k]
heißen.
So kann es schnell sein, dass Du auf einen Index zuzugreifen versucht, der gar nicht existiert, und dann ist es kein Wunder, wenn Dein Programm lustige Sachen macht

P.S. Du hast immer noch nicht die Variable Suchbegriff" mit Leben gefüllt :stupid:

Sir Rufo 9. Apr 2012 07:37

AW: Kombinieren von Repeat- mit For-Schleifen
 
Evtl. sollte man "sprechende" Namen benutzen
Delphi-Quellcode:
-------------------------------------------------------------
procedure TFrKundenliste.cmdSucheClick(Sender: TObject);
Var lCol, lRow : Integer;
    Suchbegriff : String;
begin
   for lCol := 0 to Kundenliste.colcount-1 do
     for lRow := 1 to Kundenliste.rowcount-1 do
       if Kundenliste.Cells[lCol, lRow] = Suchbegriff then
       begin
         ShowMessage('Gefunden!');
         Exit;
       end;
  ShowMessage('Pech gehabt!');
end;
--------------------------------------------------------------

Schüler 9. Apr 2012 08:40

AW: Kombinieren von Repeat- mit For-Schleifen
 
Oh! Danke euch, manchmal übersehe ich das offensichtliche oder mache Leichtsinnsfehler!:thumb:


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