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

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

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

Delphi.int.ru Expert

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

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

#   

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


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

Подробнее »



Вопрос # 877

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

Приветствую, уважаемые эксперты!
У меня созрел такой вопрос: можно ли с помощью CreateOleObject(\'Excel.Application\') экспортировать данные в ячейки EXEL, например
Sheet.Cells[1,2]:=string1;
Sheet.Cells[2,6]:=\'string2;
Sheet.Cell[8,100]:=string3;
....
и программно сохранить в .xls, при этом не постоянно прятать само окно exel?
Заранее спасибо.

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

Вопрос задал: Phoenix (статус: Посетитель)
Вопрос отправлен: 29 августа 2007, 01:37
Состояние вопроса: открыт, ответов: 1.

Ответ #1. Отвечает эксперт: ANBsoft

Здравствуйте, Phoenix!
Все возможно, и несложно.
Что хорошо, так это то, что можно записать макрос в Excel, переписать его под синтаксис Delphi и все работает

Приложение:
  1. var ExcelApp, Book, Sheet, V:Variant;
  2. Begin
  3. ExcelApp:=CreateOleObject('Excel.Application');
  4. ExcelApp.Workbooks.Add[XLWBatWorksheet]; // xlWBATWorksheet = -4167
  5. Book:=ExcelApp.Workbooks[1];
  6. Sheet:=Book.Worksheets[1];
  7.  
  8.  
  9.  
  10.  
  11. V:=VarArrayCreate([1,10,1,10],varVariant);
  12.  
  13. Sheet.Range[Sheet.Cells[1,1],Sheet.Cells[10,10]]:=v;
  14. VarClear(V);
  15.  
  16. End;


Ответ отправил: ANBsoft (статус: Студент)
Время отправки: 29 августа 2007, 09:07
Оценка за ответ: 5

Комментарий к оценке: о, спасибо большое, но еще один небольшой вопрос ниже

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

Всего сообщений: 2; последнее сообщение — 30 августа 2007, 09:06; участников в обсуждении: 2.
Phoenix

Phoenix (статус: Посетитель), 29 августа 2007, 14:45 [#1]:

Как все-таки добалять к уже имеющимся яцейкам? Например:
Sheet.Cells[X,1]:=\'Привет\'; //Где X=первая пустая после последней заполенной.
ANBsoft

ANBsoft (статус: Студент), 30 августа 2007, 09:06 [#2]:

Если документ уже заполнеy, то перебираем ячейки пока не найдем последнюю заполненную.
Примерно так.
X:=1;
while Sheet.Cells[X,1].Value<>\'\' do Inc(X);
После этого в Х номер первой свободной ячейки.

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

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