AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein GUI-Design mit VCL / FireMonkey / Common Controls Delphi StringGrid nach doppelten Einträgen durchsuchen
Thema durchsuchen
Ansicht
Themen-Optionen

StringGrid nach doppelten Einträgen durchsuchen

Ein Thema von Micha · begonnen am 30. Jun 2004 · letzter Beitrag vom 2. Jul 2004
Antwort Antwort
Seite 1 von 2  1 2      
Micha

Registriert seit: 21. Jul 2003
Ort: Neumarkt
263 Beiträge
 
#1

StringGrid nach doppelten Einträgen durchsuchen

  Alt 30. Jun 2004, 15:10
Ich hoffe mal mir kann bei meinem Problem wer weiterhelfen, bin leider noch net so fit in Delphi.

Ich lade eine Excel-Tabelle in ein StringGrid und möchte mir dann in einer Listbox die Werte ausgeben, die in einer bestimmten Spalte mehrfach vorkommen.

Wie ich nach einem best. String suche hab ich mir hier im Forum schon zusammengesucht:

Delphi-Quellcode:
procedure TForm1.Button3Click(Sender: TObject);
var suchtext:string;
    r,c : integer;
    gefunden:boolean;
begin
   gefunden:=False;
   suchtext:=edit1.Text;
    if trim(suchtext) <> 'then
     begin
      For r:=0 to StringGrid1.RowCount-1 do
       For c:=0 to StringGrid1.ColCount-1 do
        If (AnsiPos(LowerCase(suchtext),LowerCase(StringGrid1.Cells[c,r])) <> 0) then
         begin
          gefunden:=True;
          zeile:=r+1;
           ShowMessage(inttostr(r));
           break;
         end;
      if not gefunden then MessageDlg('" '+suchtext+'" wurde nicht gefunden', mtInformation, [mbOK],0);
     end;
end;
Aber leider weiß ich nicht, wie ich mir die Schleife bauen soll, damit er mir die ausgibt, die mehrfach enthalten sind.

Ich hoffe, mir kann jemand weiterhelfen.

Vielen Dank im Voraus.
  Mit Zitat antworten Zitat
Niko

Registriert seit: 23. Jun 2003
416 Beiträge
 
Delphi 2006 Professional
 
#2

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 1. Jul 2004, 19:59
Du könntest alle Zellen der Spalte durchgehen, jeweils den Wert lesen und nach diesem suchen. Dabei darfst du dann nur nicht abbrechen wenn der String das erste mal gefunden wird, sondern musst stattdessen die Anzahl der Fundstellen zählen - ist die größer 1 kommt der String merfach vor und du überträgst ihn in deine Listbox.
"Electricity is actually made up of extremely tiny particles called electrons, that you cannot see with the naked eye unless you have been drinking." (Dave Barry)
  Mit Zitat antworten Zitat
Micha

Registriert seit: 21. Jul 2003
Ort: Neumarkt
263 Beiträge
 
#3

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 08:24
ja, des wär eigentlich genau des. *g*

Aber ich komm da net ganz zurecht. Ich weiß einfach net, wie ich die Schleife dazu bauen soll.
  Mit Zitat antworten Zitat
Niko

Registriert seit: 23. Jun 2003
416 Beiträge
 
Delphi 2006 Professional
 
#4

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 10:29
Sollte in etwa so aussehen:

Delphi-Quellcode:
procedure TForm1.Button3Click(Sender: TObject);

  function SearchString(Column: Integer; Str: String): Integer;
  // gibt die Anzahl der Fundstellen von Str in der Spalte Column zurück
  var
    r: Integer;
  begin
    Result := 0;
    if Trim(Str) <> 'then
    begin
      for r := 0 to StringGrid1.RowCount - 1 do
        if (AnsiPos(LowerCase(Str), LowerCase(StringGrid1.Cells[Column, r])) <> 0) then
          Inc(Result);
    end;
  end;

const
  Column = 1; // Spalte, in der gesucht werden soll
var
  r: Integer;
begin
  for r := 0 to StringGrid1.RowCount - 1 do
  begin
    if SearchString(Column, StringGrid1.Cells[Column, r]) > 1 then
      ListBox1.Items.Add(StringGrid1.Cells[Column, r]);
  end;
end;
"Electricity is actually made up of extremely tiny particles called electrons, that you cannot see with the naked eye unless you have been drinking." (Dave Barry)
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: München
11.412 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 10:32
@Micha: Um wieviele Daten handelt es sich hier eigentlich? Mehrere tausend Zellen oder, sagen wir mal, weniger als 5000?

......
Daniel W.
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
Micha

Registriert seit: 21. Jul 2003
Ort: Neumarkt
263 Beiträge
 
#6

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 11:03
Hey, klasse Niko funktioniert einwandfrei. DANKESCHÖÖÖN

Jetz muss ich mir des Ding aber erstmal anschauen, dass ich da auch durchsteig.

@sakura: sind ca. 3000 Zeilen
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: München
11.412 Beiträge
 
Delphi 11 Alexandria
 
#7

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 11:05
Zitat von Micha:
@sakura: sind ca. 3000 Zeilen
Dann gib mir mal ein bisschen Zeit und ich schreibe Dir eine Unit, welche das ganze auf Geschwindigkeit auslegt (ich versuche es zumindest )

......

P.S.: Ich sehe gerade, daß Du es spaltenweise machst, dann sollte es schnell genug sein Vergiss es, zumindest für Dein Problem, ich schreibe es mal generell
Daniel W.
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
Micha

Registriert seit: 21. Jul 2003
Ort: Neumarkt
263 Beiträge
 
#8

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 11:20
Wow, stark, danke Sakura
  Mit Zitat antworten Zitat
Micha

Registriert seit: 21. Jul 2003
Ort: Neumarkt
263 Beiträge
 
#9

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 11:35
Eine Frage hab ich noch:

Delphi-Quellcode:
if (AnsiPos(LowerCase(Str), LowerCase(StringGrid1.Cells[Column, r])) <> 0) then
          Inc(Result);
Wenn ich zwei Datensätze habe "AB" und "ABCDE" gibt er mir die, auf Grund von AnsiPos ja auch als doppelt aus.
Das möchte ich aber nicht. Ich möchte wirklich die raussuchen, die wirklich identisch sind.

Habt ihr da nochmal ne Lösung für mich?
  Mit Zitat antworten Zitat
Benutzerbild von ibp
ibp

Registriert seit: 31. Mär 2004
Ort: Frankfurt am Main
1.511 Beiträge
 
Delphi 7 Architect
 
#10

Re: StringGrid nach doppelten Einträgen durchsuchen

  Alt 2. Jul 2004, 11:50
ja, mit einem direkten vergleich, ohne die pos-funktion...

Delphi-Quellcode:
if LowerCase(Str)=LowerCase(StringGrid1.Cells[Column, r]) then
  Inc(Result);
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 02:47 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