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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 25.07.2025, 19:16
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию Импорт данных из Excel

Здравствуйте, при попытке импортировать файл возникает ошибка "К сожалению нам не удалось найти файл H:\Pro\1.xls. Возможно он был перемещен, переименован"
Код:
ExcelApp := CreateOleObject('Excel.Application');
 ExcelApp.Workbooks.Open('H:\Pro\1.xls')
Файл 1.xls находится в папке с проектом.
Подскажите, почему возникает такая ошибка?
Ответить с цитированием
  #2  
Старый 27.07.2025, 20:00
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, для начала проверь, что файл не заблокирован (например, уже не открыт в другой копии Excel'я).
Ответить с цитированием
  #3  
Старый 28.07.2025, 08:59
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Excel не запущен. Файл не открыт. После нажатия на команду по которой должен работать код
Код:
ExcelApp := CreateOleObject('Excel.Application');
 ExcelApp.Workbooks.Open('H:\Pro\1.xls')
Excel появляется в списке фоновых процессов.
Ответить с цитированием
  #4  
Старый 28.07.2025, 18:31
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну, у меня это работает:
Код:
procedure TForm1.Button1Click(Sender: TObject);
var
  ExcelApp : Variant;
  Workbook : Variant;
begin
  ExcelApp := CreateOleObject('Excel.Application');
  Workbook := ExcelApp.Workbooks.Open('C:\Users\xxxxx xxxxxx\Documents\Сказка.Оружие.xls');
  ExcelApp.Visible := True;
end;
только еще в uses руками добавил "ComObj, ActiveX".
Если задать неправильно имя файла (добавил "1" в имя в конце), то действительно вылетает ошибка. Т.е. подозреваю, что все-таки что то не так с именем файла.
Попробуй для начала выбрать файл в OpenDialog:
Код:
procedure TForm1.Button1Click(Sender: TObject);
var
  ExcelApp : Variant;
  Workbook : Variant;
begin
  if OpenDialog1.Execute then
  begin
    ExcelApp := CreateOleObject('Excel.Application');
    Workbook := ExcelApp.Workbooks.Open(OpenDialog1.FileName);
    ExcelApp.Visible := True;
  end;
end;
Тут уж точно имя файла будет правильное.

ЗЫ. Еще вариант - неправльный формат файла.
Ответить с цитированием
  #5  
Старый 08.08.2025, 23:12
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Изначально я хотел записать из уже созданного заранее файла Excel с заданным количеством строк и столбцов в массив числовые данные.
Код:
 ExcelApp := CreateOleObject('Excel.Application');
  ExcelApp.Workbooks.Open('C:\Pro\1.xlsx');
xx := ExcelApp.ActiveCell.Row;
 yy := ExcelApp.ActiveCell.Column;
for i:=1 to yy do
   for j:=1 to xx do
   Mas[i,j]:=
Подскажите, к чему надо приравнивать двухмерный массив Mas, чтобы записались данные из 2 столбцов и 5 строк?
Ответить с цитированием
  #6  
Старый 10.08.2025, 04:34
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Что то типа того:
Код:
    // Access the first worksheet
    Worksheet := Workbook.Worksheets[1];

    // Access a specific cell (e.g., A1)
    Cell := Worksheet.Cells[1, 1];
    CellValue := Cell.Value;
Ответить с цитированием
  #7  
Старый 10.08.2025, 18:09
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Что значит данный код?
Код:
Cell := Worksheet.Cells[1, 1];
CellValue := Cell.Value;
Какого типа должен быть массив куда записывают значения из ячеек Excel?

Последний раз редактировалось Maks19, 10.08.2025 в 18:12.
Ответить с цитированием
  #8  
Старый 10.08.2025, 18:53
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Ну. очевидно, сначала получаем сылку на ячейку страницы книги Excel, потом из ячейки получаем значение. Тип - Variant, потом можно попробоывть конвертировать в более удобный тип, если уверен в типе данныз в ячейках, то можно и сразу попробовать.
Ответить с цитированием
  #9  
Старый 10.08.2025, 22:23
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

А если нужно получить несколько значений из x строк и y столбцов числовых данных?

Код:
ExcelApp := CreateOleObject('Excel.Application');
  ExcelApp.Workbooks.Open('C:\Pro\1.xlsx');
x := ExcelApp.ActiveCell.Row;
 y := ExcelApp.ActiveCell.Column;
for i:=1 to yy do
   for j:=1 to xx do
   Mas[i,j]:=ExcelSheet.Cells[i, j];
Возникает ошибка. В какой момент нужно конвертировать?

Последний раз редактировалось Maks19, 10.08.2025 в 23:14.
Ответить с цитированием
  #10  
Старый 10.08.2025, 23:05
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Ну. очевидно, сначала получаем сылку на ячейку страницы книги Excel, потом из ячейки получаем значение. Тип - Variant, потом можно попробоывть конвертировать в более удобный тип, если уверен в типе данныз в ячейках, то можно и сразу попробовать.
А сразу как?
Ответить с цитированием
  #11  
Старый 11.08.2025, 17:33
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

ну, если ты уверен в данных, то можно просто присвоить (либо использовать спец. функцию):
Код:
var
  v : Variant;
  i1, i2 : Integer;
begin
  v := 123;
  i1 := v;
  i2 := VarAsType(v, varInteger);
end;

Если не уверен, то лучше через TryStrToInt (вариант всегда можно конвертировать в строку):
Код:
var
  v : Variant;
  i : Integer;
begin
  v := 123;
  i := StrToIntDef(v, 0);
end;
Ответить с цитированием
  #12  
Старый 23.08.2025, 12:54
Maks19 Maks19 вне форума
Начинающий
 
Регистрация: 19.06.2019
Сообщения: 126
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

И все-таки к чему надо приравнивать двухмерный массив Mas, чтобы записались данные из 2 столбцов и 5 строк?
Ответить с цитированием
  #13  
Старый 24.08.2025, 05:25
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,107
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Госпадя!!!
Ну надо 30 минут, что бы из кусочков в теме собрать нужный код и отладить его:
Код:
unit Unit1;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, ComObj, Vcl.StdCtrls;

type
  TInt2dArray = Array Of Array Of Integer;

  TForm1 = class(TForm)
    Button1: TButton;
    Memo1: TMemo;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
    procedure ReadInt2dArrayFromExcel(AFileName : String; ASheet, AStartCol, AStartRow, ANan : Integer; var Result : TInt2dArray);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
const
  xlsFile : String = 'c:\Work\test.xls';
var
  arr : TInt2dArray;
  I, J : Integer;
begin
  Memo1.Clear;
  SetLength(arr,2);
  For I := Low(arr) To High(arr) Do
    SetLength(arr[i],5);

  ReadInt2dArrayFromExcel(xlsFile,1,2,2,-1,arr);
  For J := Low(arr[0]) To High(arr[0]) Do
    Memo1.Lines.Add(Format('%d  %d',[arr[0,J], arr[1,J]]));
end;

procedure TForm1.ReadInt2dArrayFromExcel(AFileName : String; ASheet, AStartCol, AStartRow, ANan : Integer; var Result : TInt2dArray);
var
  ExcelApp : Variant;
  WorkBook : Variant;
  WorkSheet : Variant;
  I, J : Integer;
begin
  // Check buffer size
  If (0 = Length(Result)) Or (0 = Length(Result[Low(Result)])) Then
    Raise Exception.Create('Buffer is not configured (cols or rows or both are equal to 0)');

  // Now open Excel and read data into array
  Try
    ExcelApp := CreateOleObject('Excel.Application');
    WorkBook := ExcelApp.Workbooks.Open(AFileName);
    Worksheet := WorkBook.Worksheets[ASheet];

    For I := Low(Result) To High(Result) Do
      For J := Low(Result[i]) To High(Result[i]) Do
        Begin
          Result[I,J] := StrToIntDef(Worksheet.Cells[AStartRow + J, AStartCol + I].Value, ANan);
        End;
    ExcelApp.Quit;
  Finally
    Worksheet := varNull;
    WorkBook := varNull;
    ExcelApp := varNull;
  End;
end;

end.

Параметры функции:
AFileName - полный путь к файлу
ASheet - номер страницы, начинается с 1
AStartCol, AStartRow - первые колонка и строка в экселе с данными
ANan - значение для подстановки, если в ячейке не целое число
Result - массив, куда писать
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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