欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

delphi excel 读取和写入

程序员文章站 2022-06-07 21:03:42
...
//读excel
function  TForm1.readExcel(fileName :WideString):TStringList;
var
    I, J ,len,ret: Integer;
    MaxRow, MaxCol: Integer;
    List, Strs: TStringList;
    ExcelApp, Sheet: Variant;
    OldTime: TDateTime;
    strChar:WideChar;
    str:WideString;
begin
    ListINFO := TStringList.Create;
    Strs := TStringList.Create;
    // 创建一个excel的ole对象
    ExcelApp := CreateOleObject('Excel.Application');
    try
        // 打开一个excel文件
        ExcelApp.WorkBooks.Open(fileName);
        ListINFO.BeginUpdate;
        try
            // 设置工作区
            ExcelApp.WorkSheets[1].Activate;
            Sheet := ExcelApp.WorkSheets[1];
            // 有数据的区域的行数和列数
            MaxRow := Sheet.UsedRange.Rows.count;
            MaxCol := Sheet.UsedRange.Columns.count;
            for I := 2 to MaxRow do
            begin
                Strs.Clear;
                for J := 1 to MaxCol do
                  begin
                  // 获得excel的数据第i行,第j列单元格内的数据
                  Strs.Add(Sheet.Cells[i,j].Value);
                end;
               ListINFO.Add(Strs.CommaText);
            end;
        finally
            // 关闭工作区
            ExcelApp.WorkBooks.Close;
            ListINFO.EndUpdate;
            end;
    finally
  // 释放ole对象
      ExcelApp.Quit;
      //ListINFO :=List;
      List.Free;
      Strs.Free;
      Result :=ListINFO;
   end;
end;

//写excel
function TForm1.writeExcel(const T,Y,W:Integer):string;
var
    I,J,len,ret: Integer;
    MaxRow, MaxCol: Integer;
    ExcelApp, Sheet,WorkBook: Variant;
    strChar:WideChar;
    str:WideString;
begin
    ExcelApp := CreateOleObject('Excel.Application');
    try
        // 打开一个excel文件
        ExcelApp.WorkBooks.Open('E:\tt.xls');
        try
            // 设置工作区
            ExcelApp.WorkSheets[1].Activate;
            Sheet := ExcelApp.WorkSheets[1];
            ExcelApp.Cells(T,Y):=W.ToString();
        finally
            // 关闭工作区
             ExcelApp.Save;
            ExcelApp.WorkBooks.Close;
            end;
    finally
      ExcelApp.Quit;
      Result :='0';
   end;
end;
相关标签: delphi excel