Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > Delphi программирование > Общие вопросы Delphi
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 15.09.2010, 10:27   #1
tarakan1983
Форумчанин
 
Аватар для tarakan1983
 
Регистрация: 09.09.2008
Сообщений: 418
По умолчанию Stringgrid как выделить несколько ячеек, скопировать и вставить.

Доброго времени суток.
1.У меня есть редактируемый stringgrid (goEditing:=true), не могу понять почему у меня не получается выделить мышкой несколько ячеек по горизонтали или по вертикали. Свойство goRangeSelect стоит в true, но при протягивании мышкой ячейки не выделяются. Если же отключить goEditing, то все выделяется. Кто подскажет почему и как быть?
2.Как мне после выделения трех ячеек, например по вертикали, скопировать их в буфер, а потом вставить в соседний или в какой-нибудь другой столбец, т.е. эффект как в Excel, ctr+с ячеек несколько, потом ctr+v в каком нибудь месте.
Нашел вот такой код для копирования и вставки
Код:
procedure TFmGrafik.CopyClick(Sender: TObject);
 var
   S: string;
   GRect: TGridRect;
   C, R: Integer;
begin
GRect := StringGrid1.Selection;
   S  := '';
   for R := GRect.Top to GRect.Bottom do
   begin
     for C := GRect.Left to GRect.Right do
     begin
       if C = GRect.Right then  S := S + (StringGrid1.Cells[C, R])
       else
         S := S + StringGrid1.Cells[C, R] + #9;
     end;
     S := S + #13#10;
 end;
   ClipBoard.AsText := S;
end;
Код:
procedure TFmGrafik.PasteClick(Sender: TObject);
var
   Grect: TGridRect;
   S, CS, F: string;
   L, R, C: Byte;
begin
GRect := StringGrid1.Selection;
   L := GRect.Left;
   R := GRect.Top;
   S := ClipBoard.AsText;
   R := R - 1;
   while Pos(#13, S) > 0 do
   begin
     R  := R + 1;
     C  := L - 1;
     CS := Copy(S, 1,Pos(#13, S));
     while Pos(#9, CS) > 0 do
     begin
       C := C + 1;
       if (C <= StringGrid1.ColCount - 1) and (R <= StringGrid1.RowCount - 1) then
         StringGrid1.Cells[C, R] := Copy(CS, 1,Pos(#9, CS) - 1);
       F := Copy(CS, 1,Pos(#9, CS) - 1);
       Delete(CS, 1,Pos(#9, CS));
     end;
     if (C <= StringGrid1.ColCount - 1) and (R <= StringGrid1.RowCount - 1) then
       StringGrid1.Cells[C + 1,R] := Copy(CS, 1,Pos(#13, CS) - 1);
     Delete(S, 1,Pos(#13, S));
     if Copy(S, 1,1) = #10 then
       Delete(S, 1,1);
   end;
end;
tarakan1983 вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Подскажите как скопировать данные из обновляемых ячеек zander Microsoft Office Excel 2 26.07.2010 09:22
Как скопировать диапазон несколько раз? Алексей11111 Microsoft Office Excel 9 19.11.2009 10:13
Как скопировать содержимое 2-х ячеек в одну... Алексей11111 Microsoft Office Excel 7 19.11.2009 07:26
Как выделить несколько страниц текста Иванов2 Microsoft Office Word 4 28.09.2009 22:24
Как выделить несколько листов сразу? frantic150 Microsoft Office Excel 3 25.06.2009 01:25