Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #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;

помогите с исключением.
Ответить с цитированием
  #2  
Старый 03.05.2010, 18:51
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

А этот код тебе в принципе не подойдет, т.к. там исключать сложно, бо как используется готовый алгоритм сортировки. Либо менять код сборки/разборки строки. Проще свое написать.

Код:
procedure StringGridRowExchange(AStringGrid : TStringGrid; I1, I2 : Integer);
var
  I : Integer;
  S : String;
begin
  For I := 0 To AStringGrid.Cols-1 Do
    Begin
       S := AStringGrid.Cells[I,I1];
       AStringGrid.Cells[I,I1] := AStringGrid.Cells[I,I2];
       AStringGrid.Cells[I,I2] := S;
    End;
end;

procedure StringGridSort(AStringGrid : TStringGrid);
var
  I, J : Interger;
  S1, S2 : String;
begin
  For I := 0 To AStringGrid.Rows-2 Do
    For J := I+1 To AStringGrid.Rows-1 Do
      Begin
        S1 := AStringGrid.Cells[0,I];
        S1 := Copy(S1,Pos(' ',S1)+1,Length(S1));
        S2 := AStringGrid.Cells[0,J];
        S2 := Copy(S2,Pos(' ',S2)+1,Length(S2));
  
        // сравниваем без учета регистра, отрезав все до первого пробела.
        If S1 > S2 Then 
           StringGridRowExchange(I,J);
      End;
end;
Ответить с цитированием
  #3  
Старый 03.05.2010, 19:44
konsul_81 konsul_81 вне форума
Прохожий
 
Регистрация: 19.04.2010
Сообщения: 21
Репутация: 10
Радость

немного не так как мне надо, но спасибо!
мне нужно задать ряд исключений.
может у кого идеи по этому поводу есть?
Ответить с цитированием
  #4  
Старый 03.05.2010, 23:20
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,093
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну так напиши эти исключения!!!
Тебе дали пример. Если тебя что-то не устраивает - доделай сам.
Собственно, вот эти строки:
Код:
S1 := AStringGrid.Cells[0,I];
S1 := Copy(S1,Pos(' ',S1)+1,Length(S1));
S2 := AStringGrid.Cells[0,J];
S2 := Copy(S2,Pos(' ',S2)+1,Length(S2));
отвечают за формирование значений для сравнения. Измени их так, как считаешь нужным.
Ответить с цитированием
  #5  
Старый 05.05.2010, 21:34
konsul_81 konsul_81 вне форума
Прохожий
 
Регистрация: 19.04.2010
Сообщения: 21
Репутация: 10
Восклицание

С ЭТИМ Я РАЗОБРАЛСЯ У МЕНЯ РУГАЕТСЯ НА СТРОКУ
Код:
StringGridRowExchange(I,J);
Ответить с цитированием
  #6  
Старый 11.05.2010, 11:09
konsul_81 konsul_81 вне форума
Прохожий
 
Регистрация: 19.04.2010
Сообщения: 21
Репутация: 10
Хорошо

вот надыбал!
самое то что нужно.
спасибо всем кто мне помогал! отдельное спасибо lmikle
Код:
function Handling ( aStr : String ) : String ;
begin
aStr := TrimLeft(Astr);
if Pos('ООО "',aStr) = 1 then aStr := copy(aStr,6,Length(aStr)-5); // задаем исключения
if Pos('ЗАО "',aStr) = 1 then aStr := copy(aStr,6,Length(aStr)-5);
if Pos('ИП ',aStr) = 1 then aStr := copy(aStr,4,Length(aStr)-3);
Result := TrimLeft(aStr);
end ;
 
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( Handling(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;

оказывается не так страшен черт, как рисуют.

выложу исходник может кому-нибудь поможет.
в нем загрузка,сохранение,вставка и удаление строк, и конечно же сортировка с исключениями.
Вложения
Тип файла: rar sgrid_grid.rar (72.9 Кбайт, 53 просмотров)
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 07:18.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025