AGB  ·  Datenschutz  ·  Impressum  







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

Redundanzprüfung

Ein Thema von danku · begonnen am 9. Mai 2006 · letzter Beitrag vom 9. Mai 2006
Antwort Antwort
Benutzerbild von danku
danku

Registriert seit: 9. Apr 2006
Ort: 32-bit Adressbus
181 Beiträge
 
Delphi 7 Enterprise
 
#1

Redundanzprüfung

  Alt 9. Mai 2006, 13:12
Im Bezug auf den Thread:

Letztes Item einer Lisbox löschen:

Delphi-Quellcode:
//Redundanz!
for i:=lbfilter.items.Count-1 downto 1
  do begin
  if lbfilter.Items.Strings[i] = lbfilter.Items.Strings[i-1]
  then begin
  showmessage('Redundanz Problem');
  edfilter.SetFocus;
  lbfilter.selected[i-1] := True;
  lbfilter.DeleteSelected;
  //Zeile markieren
  end;

  lbfilter.Selected[i];
ich setz die daten von einem Tedit in eine Tlistbox.
die prüfung funktioniert einwandfrei, bis aber eine zahl in das Tedit geschrieben wird,
die in der tlistbox an letzter stelle steht. da gibts einen crash.
wie kann ich den umgehen zumal ja der rest auch geht?
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Redundanzprüfung

  Alt 9. Mai 2006, 13:30
Hi.

Ich kann deinen Fehler nirgends entdecken - vielleicht steckt er in dem Code, den ich nicht sehen kann?

Delphi-Quellcode:
function CheckItems(lb: TListBox): Integer;
var
  i: Integer;
begin
  with lb do
  begin
    for i := Pred(items.Count) downto 1 do
      if Items[i] = Items[i-1] then
        Selected[i-1] := True;
    Result := SelCount;
  end;
end;

procedure TDemoForm.CheckButtonClick(Sender: TObject);
begin
  if CheckItems(lbFilter) > 0 then
  begin
    lbFilter.DeleteSelected;
    ShowMessage('Houston, we''ve got a problem');
    edFilter.SetFocus;
  end;
end;
Grüße vom marabu
  Mit Zitat antworten Zitat
Benutzerbild von danku
danku

Registriert seit: 9. Apr 2006
Ort: 32-bit Adressbus
181 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Redundanzprüfung

  Alt 9. Mai 2006, 13:34
hm eigentlich nicht.

das ist die methode von dem tbutton:
Delphi-Quellcode:
procedure Tfmformat.baddClick(Sender: TObject);
var counter,i:integer;

begin
lbfilter.items.Add(edfilter.text);
lbfilter.Sorted:=true;
edfilter.Clear;
counter:= lbfilter.Items.Count;
label2.caption:='(' + inttostr(counter) + ')';
if label2.caption ='(0)'
then label2.caption:='()';

change:=true;

//Redundanz!
for i:=lbfilter.items.Count-1 downto 1
  do begin
  if lbfilter.Items.Strings[i] = lbfilter.Items.Strings[i-1]
  then begin
  showmessage('Redundanz Problem');
  edfilter.SetFocus;
  lbfilter.selected[i-1] := True;
  lbfilter.DeleteSelected;
  //Zeile markieren
  end;

  lbfilter.Selected[i];


 change:=true;
 
 end;
end;


übrigens geht deins nicht. es werden trotzdem gleiche strings geaddet.
  Mit Zitat antworten Zitat
sir-archimedes

Registriert seit: 2. Jan 2006
Ort: Münster
167 Beiträge
 
Delphi 2006 Professional
 
#4

Re: Redundanzprüfung

  Alt 9. Mai 2006, 13:51
Ich habe da mal eine ganz pragmatische Frage: wieso fügst du den Eintrag erst zur Listbox hinzu, prüfst dann ob er doppelt auftritt und schmeißt ihn wieder raus? Prüfe vorher, ob der Eintrag bereits vorkommt und du hast deine Probleme nicht.
  Mit Zitat antworten Zitat
TBx
(Administrator)

Registriert seit: 13. Jul 2005
Ort: Stadthagen
1.875 Beiträge
 
Delphi 12 Athens
 
#5

Re: Redundanzprüfung

  Alt 9. Mai 2006, 13:55
Hallo Danku!

Was soll das Ganze denn bewirken?

Wenn Du nur verhindern möchtest, daß über das Editfeld doppelte Werte in die Listbox übergeben werden, so kannst Du das am einfachsten bei der Übergabe lösen:

Delphi-Quellcode:
procedure Button1Click (Sender:TObject);
begin
  if lbfilter.items.indexof (edfilter.text) > -1 then
  begin
    showmessage ('Redundanzproblem!');
    edfilter.SetFocus;
  end
  else
  begin
    lbfilter.items.Add (edfilter.Text);
  end;
end;
Dies hat den Vorteil, daß alle Items dahingehend überprüft werden, ob sie dem Text des Edits entsprechen.

Bei Deiner Methode werden immer nur zwei aufeinanderfolgende Einträge verglichen, sodaß Eingaben ala
eins
zwei
drei
eins
zwei
drei
möglich wären.

Zur Erklärung, warum Du eine Zugriffsverletzung bekommst, wenn der Wert in der letzten und in der vorletzten Zeile Deiner Listbox identisch sind, liegt in dieser Zeile:

lbfilter.selected [i] Diese Zeile ist zum einen sinnlos (wie in dem vorherigen Thread erklärt), zum anderen greift sie in diesem Fall auf ein nicht mehr vorhandenes Item:
Du hast zuvor das Item, das einen Platz zuvor in der Liste steht [i-1] gelöscht. Dadurch rückt item [i] auf den Platz von item [i-1] auf und ein Item [i] ist nicht mehr vorhanden.

Hope it helps

Thomas
Thomas Breitkreuz
  Mit Zitat antworten Zitat
Benutzerbild von danku
danku

Registriert seit: 9. Apr 2006
Ort: 32-bit Adressbus
181 Beiträge
 
Delphi 7 Enterprise
 
#6

Re: Redundanzprüfung

  Alt 9. Mai 2006, 16:28
@Onlinekater:

Zitat:
Bei Deiner Methode werden immer nur zwei aufeinanderfolgende Einträge verglichen, sodaß Eingaben ala
eins
zwei
drei
eins
zwei
drei
möglich wären.
Zitat von dominik.boehm:
Ich habe da mal eine ganz pragmatische Frage: wieso fügst du den Eintrag erst zur Listbox hinzu, prüfst dann ob er doppelt auftritt und schmeißt ihn wieder raus? Prüfe vorher, ob der Eintrag bereits vorkommt und du hast deine Probleme nicht.
ja ist ja logisch. ich hatte mir das so vorgestellt, dass die werte erst in die tstringgrid geschrieben werden (sortiert), der user kann sie sehen und die werte dann herausgefiltert werden. bei doppelwerten eben die fehlermeldung.

man kann natürlich aber auch vorher die werte schon abfangen.
aber das ist ansichtssache finde ich
  Mit Zitat antworten Zitat
Antwort Antwort


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 03:13 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