Это для того, чтобы не применять локальные для каждой версии названия "Excel.Application.8",
"Excel.Application.9". Ко всему прочему приведенный пример не работает с Excel95.
Перевод контента на русский язык:
Это программное обеспечение Delphi, демонстрирующее работу с Microsoft Excel с помощью автоматизации OLE (Object Linking and Embedding). Программа позволяет открыть файл Excel, прочитать его содержимое и закрыть.
Процедура ConnectToExcelServer создает экземпляр объекта приложения Excel и открывает указанный файл Excel. Она также устанавливает видимость приложения Excel в False, что означает, что приложение Excel будет работать в фоновом режиме без отображения.
Процедура LoadLists загружает список листов из открытого файла Excel в комбобокс.
Процедура LoadExcel читает данные с выбранного листа и хранит их в базе данных с помощью хранимой процедуры. Она также обрабатывает ошибки, которые могут возникнуть при выполнении хранимой процедуры.
Вот некоторые наблюдения и предложения:
Программа использует регистрационный ключ для определения версии Excel, установленной на системе. Это полезно потому что различные версии Excel имеют разные объекты автоматизации с разными свойствами и методами.
Программа использует позднюю связку, что означает, что она создает экземпляр объекта приложения Excel с помощью функции CreateOleObject. Этот подход может быть более гибким, чем ранняя связка, но требует больше кода для управления ссылками на объекты.
Программа предполагает, что пользователь установил Excel на свою систему и знает путь к файлу исполняемого файла Excel. Если это не так, программа будет выдавать ошибку при создании экземпляра объекта приложения Excel.
Программа не обрабатывает исключения должным образом. Например, если файл Excel не может быть найден или если есть проблема с данными листа, программа может рухнуть или дать неожиданные результаты.
Программа использует хранимую процедуру для хранения данных в базе данных, но не предоставляет никакой обработки ошибок для хранимой процедуры.
Вот альтернативное решение, использующее раннюю связку и обрабатывающее исключения лучше:
procedureTEnemaDM.ConnectToExcelServer(FileName:String);varExcelApp:Variant;begintryExcelApp:=CreateOleObject('Excel.Application');ExcelApp.Visible:=False;ExcelApp.Workbooks.Open(FileName);exceptonE:ExceptiondoMessageDlg(E.Message,mtError,[mbOk],0);end;end;procedureTEnemaDM.DisconnectExcelServer;begintryExcel.Quit;exceptonE:ExceptiondoMessageDlg(E.Message,mtError,[mbOk],0);end;end;procedureTMainForm.LoadLists(WorkBooks:Variant);varI:Integer;beginifnotVarIsNull(WorkBooks)thenbeginExcelListBox.Items.Clear;forI:=1toWorkBooks.WorkSheets.CountdobeginExcelListBox.Items.Add(VarToStr(WorkBooks.WorkSheets[I].Name));end;end;end;procedureTEnemaDM.LoadExcel(WorkSheet:Variant);varI:Integer;ErrorList:TStrings;beginwithMainFormdotryErrorList:=TStringList.Create;tryforI:=1toWorkSheet.Cells.CurrentRegion.Rows.Countdobegintry// Вызов хранимой процедуры здесь// ...exceptonE:ExceptiondoErrorList.Add(GetErrorCurrentValue+#32+E.Message);end;end;ifErrorList.Count=0thenMessageDlg('Данные успешно загружены',mtInformation,[mbOk],0)elseFormForErrors.SetErrorList(ErrorList);finallyErrorList.Free;end;exceptonE:ExceptiondoMessageDlg(E.Message,mtError,[mbOk],0);end;end;
Альтернативное решение использует раннюю связку для создания экземпляра объекта приложения Excel и обрабатывает исключения лучше. Оно также предполагает, что пользователь установил Excel на свою систему и знает путь к файлу исполняемого файла Excel.
Пример статьи: 'Пример работы с Microsoft Excel через OLE в Delphi-приложении, демонстрирующий загрузку данных из Excel-файла и их передачу в хранимую процедуру для сохранения в SQL-базе данных.'
Комментарии и вопросы
Получайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Telegram-канал delphi_kansoftware и будьте в курсе последних тенденций в разработке под Linux, Windows, Android и iOS
Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта.