마음의 안정을 찾기 위하여 - [Delphi] TStringList의 중복된 아이템 제거하기.
1948057
62
283
관리자새글쓰기
태그위치로그방명록
별일없다의 생각
dawnsea's me2day/2010
색상(RGB)코드 추출기(Color...
Connection Generator/2010
최승호PD, '4대강 거짓말 검...
Green Monkey**/2010
Syng의 생각
syng's me2DAY/2010
천재 작곡가 윤일상이 기획,...
엘븐킹's Digital Factory/2010
[Delphi] TStringList의 중복된 아이템 제거하기.
Delphi | 2009/03/10 10:01


출처 : http://delphi.about.com/od/delphitips2009/qt/remove-duplicat.htm

TMemo / TComboBox / TListBox등에서 모두 사용가능한 방법이다.

procedure RemoveDuplicates(const stringList : TStringList) ;
Var
  Buffer : TStringList;
  Cnt    : Integer;
begin
  StringList.Sort;
  Buffer := TStringList.Create;
  Try
    Buffer.Sorted     := True;
    Buffer.Duplicates := dupIgnore;
    Buffer.BeginUpdate;
    For Cnt := 0 To stringList.Count - 1 Do begin
      Buffer.Add(StringList[cnt]) ;
    end;
    Buffer.EndUpdate;
    StringList.Assign(Buffer) ;
  Finally
    FreeandNil(Buffer) ;
  End;
end;


[사용 예]
var
  sl : TStringList;
  cnt : integer;
begin
  Randomize;
  sl := TStringList.Create;
  Try
    For cnt := 1 To 100 Do
      sl.Add(IntToStr(Random(100))) ;

    sl.Sorted := True;
    sl.Duplicates := dupIgnore;
    ShowMessage('With duplicates: ' + #13#10 + IntToStr(sl.Count)) ;
    RemoveDuplicates(sl) ;
    ShowMessage('Without duplicates: ' + #13#10 + IntToStr(sl.Count)) ;
  Finally
    sl.Free;
  End;

2009/03/10 10:01 2009/03/10 10:01
Article tag list Go to top
View Comment 0
Trackback URL :: 이 글에는 트랙백을 보낼 수 없습니다
 
 
 
 
: [1] ... [374][375][376][377][378][379][380][381][382] ... [855] :
«   2021/10   »
          1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31            
전체 (855)
출판 준비 (0)
My-Pro... (41)
사는 ... (492)
블로그... (22)
My Lib... (32)
게임 ... (23)
개발관... (3)
Smart ... (1)
Delphi (75)
C Builder (0)
Object... (0)
VC, MF... (9)
Window... (1)
Open API (3)
Visual... (0)
Java, JSP (2)
ASP.NET (0)
PHP (4)
Database (12)
리눅스 (28)
Windows (23)
Device... (1)
Embedded (1)
게임 ... (0)
Web Se... (2)
Web, S... (19)
잡다한... (5)
프로젝트 (0)
Personal (0)
대통령... (9)
Link (2)