Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Основная";
Текущий архив: 2005.01.23;
Скачать: [xml.tar.bz2];

Вниз

Сортировка в StringGrid   Найти похожие ветки 

 
DDDeN   (2005-01-11 11:56) [0]

Как отсортировать СтрингГрид по определенному полю (по возрастанию или убыванию) или по группе указанных полей?


 
P.N.P. ©   (2005-01-11 12:22) [1]


type TStringGridExSortType = (srtAlpha,srtInteger,srtDouble);

procedure GridSort(SG : TStringGrid; ByColNumber,FromRow,ToRow : integer;
                  SortType : TStringGridExSortType = srtAlpha);
var Temp : TStringList;

   function SortStr(Line : string) : string;
   var RetVar : string;
   begin
     case SortType of
          srtAlpha   : Retvar := Line;
          srtInteger : Retvar := FormatFloat("000000000",StrToIntDef(trim(Line),0));
          srtDouble  : try
                         Retvar := FormatFloat("000000000.000000",StrToFloat(trim(Line)));
                       except
                         RetVar  := "0.00";
                       end;
     end;

     Result := RetVar;
   end;

   // Ðåêóðñèâíûé QuickSort
   procedure QuickSort(Lo,Hi : integer; CC : TStrings);

       procedure Sort(l,r: integer);
       var  i,j : integer;
            x   : string;
       begin
         i := l; j := r;
         x := SortStr(CC[(l+r) DIV 2]);
         repeat
           while SortStr(CC[i]) < x do inc(i);
           while x < SortStr(CC[j]) do dec(j);
           if i <= j then begin
             Temp.Assign(SG.Rows[j]);      // &#204;&#229;&#237;&#255;&#229;&#236; &#236;&#229;&#241;&#242;&#224;&#236;&#232; 2 &#241;&#242;&#240;&#238;&#234;&#232;
             SG.Rows[j].Assign(SG.Rows[i]);
             SG.Rows[i].Assign(Temp);
             inc(i); dec(j);
           end;
         until i > j;
         if l < j then sort(l,j);
         if i < r then sort(i,r);
       end;

    begin {quicksort};
      Sort(Lo,Hi);
    end;

begin
 Temp := TStringList.Create;
 QuickSort(FromRow,ToRow,SG.Cols[ByColNumber]);
 Temp.Free;
end;


 
DDDeN   (2005-01-11 12:39) [2]

Ого!!!
Один комментарий непонятен ;)



Страницы: 1 вся ветка

Форум: "Основная";
Текущий архив: 2005.01.23;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.041 c
9-1097572868
VolanD
2004-10-12 13:21
2005.01.23
Direct3D


6-1097572240
Rafl
2004-10-12 13:10
2005.01.23
Поиск компьютеров


14-1105107968
mutuaservices
2005-01-07 17:26
2005.01.23
Вопросик.


3-1103223045
Flagman
2004-12-16 21:50
2005.01.23
TQuery + Paradox + CD ?


1-1105606735
TUser
2005-01-13 11:58
2005.01.23
Self в потоке





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский