Показать сообщение отдельно
  #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 - массив, куда писать
Ответить с цитированием