Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 5 497

/ вопрос открыт /

Здравствуйте, уважаемые эксперты!
Подскажите как реализовать следующее.
Имеются много файлов Excel (Tabl1.xls,Tabl2.xls......Tabl30.xls)
Необходимо поочередно открыть каждый файл, найти в первой колонке единственного листа все строки, содержащие текст "Иванов Иван Иванович" и скопировать эти строки в Лист1 Книги TABL_ALL.xls, предварительно в строке выше копируемых данных указать имя файла с которого эти данные скопированы.
Т.е. должно получиться построчно в виде
Tabl1.xls
Иванов Иван Иванович_бла_бла_бла_бла
Иванов Иван Иванович_блу_блу_блу_блу
Tabl12.xls
Иванов Иван Иванович_1_2_3_4
Иванов Иван Иванович_23_45_56_15
.............
Tabl28.xls
Иванов Иван Иванович_6_4_10_5
Иванов Иван Иванович_90_23_56_78

Найти строку в одном файле не проблема, если я правильно понимаю (см.приложение)
А как в цикле по файлам и как с именем файла????
Заранее благодарен
Al_Sha

Приложение:
  1. procedure TForm1.Button1Click(Sender: TObject);
  2. var
  3. XL: Variant;
  4. i: Integer;
  5. begin
  6. XL := CreateOLEObject('Excel.Application');
  7. XL.WorkBooks.add;
  8. XL.WorkBooks.Open('C:\Tabl1.xls');
  9. L.Visible:=true;
  10.  
  11.  
  12. begin
  13.  
  14. begin
  15. XL.Rows[I].Copy;
  16. end;
  17. end;
  18. end;


Al_Sha Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: Al_Sha (статус: Посетитель)
Вопрос отправлен: 12 июля 2011, 23:30
Состояние вопроса: открыт, ответов: 0.


Мини-форум вопроса

Всего сообщений: 2; последнее сообщение — 13 июля 2011, 09:49; участников в обсуждении: 2.
min@y™

min@y™ (статус: Доктор наук), 13 июля 2011, 08:27 [#1]:

Цитата (Al_Sha):

А как в цикле по файлам и как с именем файла????

var
  Index: Integer;
  FileName: string;
begin
  for Index:= 1 to 30 do
    begin
      FileName:= Format('C:\Tabl%d.xls', [Index]); // имя файла
 
      // ну а здесь делаешь ту хрень,
      // которая у тебя в приложении к вопросу.
    end;
end;
Делаю лабы и курсачи по Delphi и Turbo Pascal. За ПИВО! Пишите в личку, а лучше в аську. А ещё лучше - звоните в скайп!
Al_Sha

Al_Sha (статус: Посетитель), 13 июля 2011, 09:49 [#2]:

Спасибо...

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 16:25
Выполнено за 0.02 сек.