Показать сообщение отдельно
  #1  
Старый 03.05.2010, 17:15
konsul_81 konsul_81 вне форума
Прохожий
 
Регистрация: 19.04.2010
Сообщения: 21
Репутация: 10
Восклицание сортировка по алфавиту в StringGrid

Всем Здравствуйте!!!
помогите пожалуйста с сортировкой по алфавиту.
единственно должно быть исключение первых символов.
есть записи типа
----------------------------------------------------
ООО "Рога",7700234511
ООО "Копыта",7700435678
ООО "Василек",7700786745
ООО "Золотое Сало",5000234654
ИП Пупкин В.В.,770012345434
ИП Череззаборногозадеришенко П.А.,770094857678
ЗАО "Шарашкин и Ко",7700341761
ООО "Чебурек",7700235527
ОАО "Газпрем",7700945420
ООО "Буржуй",7700000123
--------------------------------------------------------
надо чтобы при сортировке исключались символы типа ООО " или ИП
и начинало сортировать с названия

вот я нашел вариант сортировки но без всяких исключений и с самых первых символов.
Код:
procedure SortStringGrid(var GenStrGrid: TStringGrid; ThatCol: Integer);
 const
  TheSeparator = '@';
 var
   CountItem, I, J, K, ThePosition: integer;
   MyList: TStringList;
   MyString, TempString: string;
 begin
  CountItem := GenStrGrid.RowCount;
  MyList        := TStringList.Create;
   MyList.Sorted := False;
   try
     begin
       for I := 1 to (CountItem - 1) do
         MyList.Add(GenStrGrid.Rows[i].Strings[ThatCol] + TheSeparator +
           GenStrGrid.Rows[i].Text);
      Mylist.Sort;
       for K := 1 to Mylist.Count do
       begin
        MyString := MyList.Strings[(K - 1)];
        ThePosition := Pos(TheSeparator, MyString);
         TempString  := '';
         TempString := Copy(MyString, (ThePosition + 1), Length(MyString));
         MyList.Strings[(K - 1)] := '';
         MyList.Strings[(K - 1)] := TempString;
       end;
      for J := 1 to (CountItem - 1) do
         GenStrGrid.Rows[J].Text := MyList.Strings[(J - 1)];
     end;
   finally
    MyList.Free;
   end;
 end;

 procedure TForm1.ToolButton17Click(Sender: TObject);
 begin
  SortStringGrid(StringGrid1, 0);
 end;

помогите с исключением.
Ответить с цитированием