ListBox Filtering - PullRequest
       14

ListBox Filtering

3 голосов
/ 21 июня 2010

У меня есть список с 10 000 предметов и много повторяющихся предметов!Я хочу сохранить его в файл без дубликатов (один элемент вместо всех копий!) И использую этот способ:

Function TMain.List_ExistsIn(ListBox_NAme: TListBox; EParameter: String): Integer;
Var
  i: Integer;
Begin
  EParameter := LowerCase(EParameter);
  Result := -1;
  For i:=0 To ListBox_Name.Items.Count - 1 Do
    If EParameter = Lowercase(ListBox_Name.Items[i]) Then Begin
      Result := i;
      Break;
    End;
End;

Я использую код выше для обнаружения существующего элемента и следующую процедуру для его сохранения:

Procedure TMain.MakeList(ListBox_Name: TListBox; FileName: String); //================
Var
  i: Integer;
  Temp_ListBox: TListBox;
Begin
  Temp_ListBox := TListBox.Create(Main);
  With Temp_ListBox Do Begin
    Parent := Main;
    Clear;
    For i:=0 To ListBox_Name.Count - 1 Do
      If Main.List_ExistsIn(Temp_ListBox, ListBox_Name.Items[i]) = -1 Then
        Items.Add(ListBox_Name.Items[i]);
    Items.SaveToFile(FileName);
    Free;
  End;
End;

Но это займет очень очень много времени, чтобы продолжить.Есть ли лучший и быстрый способ?Спасибо.

Ответы [ 2 ]

7 голосов
/ 21 июня 2010

Попробуйте это

procedure TForm1.FormCreate(Sender: TObject);
var
  StrList: TStringList;
  I: Integer;
begin
  StrList := TStringList.Create;
  StrList.Sorted := True;
  StrList.Duplicates := dupIgnore;
  StrList.AddStrings(ListBox1.Items);  //Your List Box Items
  StrList.SaveToFile('C:\abc.txt');
  StrList.Free; //Cleanup
end;
1 голос
/ 25 июня 2010

Остерегайтесь печально известного эффекта CompareString () ...

Включить 59A, 5-9A, 59-A, -59-A в отсортированный список 1. Список становится 59А, -59-А, 5-9А, 59-А и .Find () или .IndexOf () не смогут найти 59-A.

Теперь вставьте те же значения в отсортированный список 2, но вставьте в порядке 59А, -59-А, 5-9А, 59-А. Список становится 59А, 59-А, -59-А, 5-9А. .Find () и .IndexOf () могут найти 59-A.

Подробнее см. в этом блоге .

...