Форум программистов, компьютерный форум, киберфорум
Delphi
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 25.11.2007
Сообщений: 66

Порча книги Excel при чтении данных из Дельфи-приложения

25.03.2011, 11:22. Показов 1358. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В Дельфи-приложении надо считать данные из Exel – листа во внутренний массив.
Используется следующий код.
Delphi
1
2
3
4
5
6
7
8
9
XLApp:= CreateOleObject('Excel.Application'); // Обьект EXCEL
   XLApp.Workbooks.Open(***/Book.xls);
   for i:=0 to npar do
         begin
           s[i] :=XLApp.WorkBooks[1].WorkSheets[1].Cells[k,i+1];
         end;
XLApp.WorkBooks.Close;
 XLApp.Quit;
  XLApp := Unassigned;
В результате после завершения приложения книга Excel откуда читались данные уменьшается по объему в несколько раз. И происходит следующее:
В содержимое 1 столбца записываются с разделителем пробел склеенное содержимое нескольких столбцов (по которым осушествлялось чтение), т.е. программа портит файл.
В чем дело? это обращение к Excel через OLE – типичное для связи с Office и технологически самое простое. Не надо только давать советы обойти этот способ через установку ODBC-драйвера к Excel и что-то в этом роде!.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.03.2011, 11:22
Ответы с готовыми решениями:

Порча xls при чтении данных из Дельфи-приложения
В Дельфи-приложении надо считать данные из Exel – листа во внутренний массив. Используется...

Excel, ошибка при записи и чтении
Здравствуйте, я бы написал в чем дело, да это уже написано в заголовке. Вот код: ...

AppCrash консольного приложения при чтении с него средствами vbs
Доброго времени суток форумчане! есть маткад он использует vbs и есть консоль на vb.net вызывающая...

3
 Аватар для palva
4278 / 2970 / 693
Регистрация: 08.06.2007
Сообщений: 9,930
Записей в блоге: 5
25.03.2011, 23:44
Привет, Женя. Наконец, установил дома Delphi 7.
Я попробовал твой код. В файле Book1.xls заполнил первую строку числами 1, 2, 3, 4, 5. Программа была следующая:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
{$APPTYPE CONSOLE}
uses
  ActiveX, ComObj, Variants;
var
  XLApp: OLEVariant;
  s: array [0..4] of String;
  i: Integer;
begin
  CoInitialize(nil);
  XLApp:= CreateOleObject('Excel.Application'); // Обьект EXCEL
  XLApp.Workbooks.Open('D:CpascalBook1.xls');
  for i:=1 to 4 do
  begin
    s[i] :=XLApp.WorkBooks[1].WorkSheets[1].Cells[1,i];
    writeln(s[i]);
  end;
  XLApp.WorkBooks.Close;
  XLApp.Quit;
  XLApp := Unassigned;
end.
Все проработало правильно, файл не изменился.

У меня русский Office 2000 со всеми патчами, проведенными с сайта Microsoft.
0
0 / 0 / 0
Регистрация: 18.04.2011
Сообщений: 4
18.04.2011, 17:24
Привет!
Лучше вместо цикла по ячейкам считывать их значения в вариантный массив - скорость намного больше! Пример:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var
  MyData: Variant;
...
XLApp:= CreateOleObject('Excel.Application'); // Обьект EXCEL
XLApp.Workbooks.Open('***/Book.xls');
with XLApp.WorkBooks[1].WorkSheets[1] do
  MyData := Range[Cells[k,1], Cells[k, npar + 1].Value;
for i:= 1 to npar + 1 do
begin
  s[i] := MyData[1, i];
end;
XLApp.WorkBooks[1].Saved := True;
XLApp.Quit;
XLApp := Unassigned;
MyData := UnAssigned;
0
0 / 0 / 0
Регистрация: 18.04.2011
Сообщений: 4
18.04.2011, 17:43
А в общем можно почитать http://www.delphikingdom.com/asp/viewitem.asp?catalogid=502
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.04.2011, 17:43
Помогаю со студенческими работами здесь

При чтении из таблицы Excel не читаются текстовые значения
Возникла странная проблема с файлом эксель. Имеется таблица с 6 колнками: Номер, инвентарный номер,...

анимацимированная gif картинка зависает при чтении excel файла
Добрый день уважаемые форумчане !!! Прошу помощи у гуру !!! пишу обработку при которой есть...

Смещение даты DateTime на 2 дня при чтении из Interop.Excel
Прочитал в умной книжке, что оказывается дата в экселе храниться в виде int64 дней с 1 января 1900...

Сортировка массива - порча данных
Добрый день! Возникла проблема с построением сортировки массива. На входе массив размерностью 20....

Импорт данных из книги Excel
Доброго времени суток. Есть кладовщик который заполняет бумажки на приход товара, расход - что кому...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru