Sources
Delphi Russian Knowledge Base
DRKB - это самая большая и удобная в использовании база знаний по Дельфи в рунете, составленная Виталием Невзоровым

Сортировка строк с украинскими символами

01.01.2007
{ **** UBPFD *********** by kladovka.net.ru ****
>> Сортировка строк с украинскими символами
 
Принцип работы функции такой же как и у стандартной функции CompareText из SysUtils. Поскольку для украинских символов строки сортируются этой функцией "как попало", то я решил написать свой CompareUkrText.
 
Зависимости: System
Автор:       Алексей Глеб, noodlesf@mail.ru, Чернигов
Copyright:   Собственное написание (Алексей Глеб)
Дата:        1 февраля 2003 г.
********************************************** }
 
Unit UkrSort;
 
Interface
 
Function CompareUkrText(S1, S2: String): integer;
 
 
//массив, который заменит ASCI таблицу
Var
 
Chars: Array[1..136] Of char=
 
('1','2','3','4','5','6','7','8','9','0','A','B','C','D','E','F','G',
   
'H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X',
   
'Y','Z','a','b','c','d','e','f','g','h','i','j','k','l','m','n','o',
   
'p','q','r','s','t','u','v','w','x','y','z','А','Б','В','Г','Ґ','Д',
   
'Е','Ё','Є','Ж','З','И','І','Ї','Й','К','Л','М','Н','О','П','Р','С',
   
'Т','У','Ф','Х','Ц','Ч','Ш','Щ','Ъ','Ы','Ь','Э','Ю','Я','а','б','в',
   
'г','ґ','д','е','ё','є','ж','з','и','і','ї','й','к','л','м','н','о',
   
'п','р','с','т','у','ф','х','ц','ч','ш','щ','ъ','ы','ь','э','ю','я');
 
Implementation
 
 
//сама функция
Function CompareUkrText(S1, S2: String): integer;
 
 
Function GetNum(C: char): integer;
   
//динам. функция получения номера символа из нашего массива
 
Var
    i
: integer;
 
Begin
   
Result:=0;
   
For i:=1 To 136 Do
     
If Chars[i]=C Then
     
Begin
       
Result:=i;
       
exit;
     
End;
 
End;
 
 
Function CompCh(C1, C2: integer): integer;
   
//динам. функция определения "что больше???"
 
Begin
   
If C1=C2 Then Result:=0;
   
If C1>C2 Then Result:=1;
   
If C1<C2 Then Result:=-1;
 
End;
Var
  i
, xS1, xS2, CurrR: integer;
Begin //начало функции сортировки
 
Result:=0;
 
CurrR:=0; //временный результат
 
If S1<>S2 Then
 
Begin
     
//сканирование сток посимвольно
   
For i:=1 To Length(S1) Do
   
Begin
     
If Length(S2)>=i Then
     
Begin
        xS1
:=GetNum(S1[i]);
        xS2
:=GetNum(S2[i]);
       
If (xS1<>0)And(xS2<>0)And(xS1<>xS2) Then
         
CurrR:=CompCh(xS1, xS2)
       
Else
       
Begin
         
If (xS1=0)Or(xS2=0) Then
         
Begin
           
If xS2=0 Then CurrR:=1;
           
If xS1=0 Then CurrR:=-1;
         
End;
       
End;
       
If CurrR<>0 Then
       
Begin
         
Result:=CurrR;
         
Exit;
       
End;
     
End
     
Else
     
Begin
       
Result:=CurrR;
       
Exit;
     
End;
   
End;
 
End;
End;
 
End.

Пример использования:

Function CustomSortProc(Item1, Item2: TListItem; ParamSort: integer): integer; Stdcall;
Begin
 
Result:=CompareUkrText(Item1.Caption, Item2.Caption);
End;
 
procedure TForm1
.FormClick(Sender: TObject);
begin
  ListView1
.CustomSort(@CustomSortProc, 0);
end;