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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.11.2011, 12:05
Red_Garry Red_Garry вне форума
Начинающий
 
Регистрация: 07.07.2011
Сообщения: 126
Репутация: 10
По умолчанию Метод Find посредством Delphi применительно к Excel

Здравствуйте!
Прошу у разбирающихся помощи. Нужен кусок кода с реализацией метода Find для листа Excel. Задача простая: в некоем диапазоне найти ячейку, значение которой равно S, где S - тестовая строка, и поместить номер строки в переменную n. Программа написана, отлажена и нормально работает, но поиск сейчас реализован методом перебора. Претензия пользователя - скорость работы. Кажется мне, что если применить Find, то будет отрабатывать быстрее.
Ответить с цитированием
  #2  
Старый 28.11.2011, 12:27
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Код:
procedure TForm1.FormCreate(Sender: TObject);
var e: OleVariant;
    n: integer;
begin
  e:= CreateOleObject('Excel.Application');
  e.Workbooks.Add;
  //вставляем в B4 текст
  e.Cells[4,2].Value:= 'Hello World!';
  e.Visible:= true;

  //поиск по книге (ставим курсор на ячейку A1)
  e.Cells[1,1].Select;
  e.Cells.Find(What:= 'Hello World!', After:= e.ActiveCell,
               LookIn:= -4123, LookAt:= 2,
               SearchOrder:= 1, SearchDirection:= 1,
               MatchCase:= false, SearchFormat:= false).Activate;
  //помещаем номер строки с заданным текстом в переменную
  n:= e.ActiveCell.Row;
  ShowMessage(inttostr(n));
end;
__________________
Google в помощь
Ответить с цитированием
  #3  
Старый 28.11.2011, 12:37
Red_Garry Red_Garry вне форума
Начинающий
 
Регистрация: 07.07.2011
Сообщения: 126
Репутация: 10
По умолчанию

Большое спасибо за ответ! А можно по паре слов по поводу смысла параметров - LookIn:= -4123, LookAt:= 2, SearchOrder:= 1, earchDirection:= 1, MatchCase:= false, SearchFormat:= false - Это чтобы выйти хотя бы на какой-то уровень осознания
Ответить с цитированием
  #4  
Старый 28.11.2011, 12:51
Аватар для Ildar-tsr
Ildar-tsr Ildar-tsr вне форума
Местный
 
Регистрация: 09.08.2011
Адрес: г.Сургут, ХМАО
Сообщения: 453
Репутация: 7402
По умолчанию

Цитата:
Сообщение от Red_Garry
Большое спасибо за ответ! А можно по паре слов по поводу смысла параметров - LookIn:= -4123, LookAt:= 2, SearchOrder:= 1, earchDirection:= 1, MatchCase:= false, SearchFormat:= false - Это чтобы выйти хотя бы на какой-то уровень осознания

LookIn - способ поиска в ячейке. Данное значение ищет искомый текст даже в формулах (такой поиск стоит по умолчанию).Например, поиск "мимо" формул - 4163.
LookAt - стандартный параметр, не знаю на что он влияет, и какие еще значения может принимать...
SearchOrder - искать по строкам (можно искать по столбцам, но по умолчанию в поиске стоит по строкам).
SearchDirection - в какую строну идти (вверх документа или вниз). Мы идем вниз, собственно по данной причине перед поиском ставим указатель на первую ячейке.
MatchCase - если true, то ищет полное совпадение искомого текста. Например, в первой ячейке текст 'Чел', а во второй 'Человек'. Если матчкэйс стоит на true, и искомое слово - 'Чел' то он найдет только первое значение. А если false, то оба.
SearchFormat - дополнительный формат поиска в excel'e. С ним не сталкивался, как пользоваться не знаю.

P.S. Если устраивает простой стандартный поиск, то можно оставить только параметры what и after. Остальные не обязательны к заполнению, но лучше все-таки использовать полную конструкцию.
__________________
Google в помощь

Последний раз редактировалось Ildar-tsr, 28.11.2011 в 12:54.
Ответить с цитированием
  #5  
Старый 28.11.2011, 12:54
Red_Garry Red_Garry вне форума
Начинающий
 
Регистрация: 07.07.2011
Сообщения: 126
Репутация: 10
По умолчанию

Большое спасибо за исчерпывающий ответ!
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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