Delphi- 操作EXCEL

  因工作需要,需要到操作EXCEL,先了解一下怎么读取EXCEL这个,做了一个DEMO,备注在这里

  一、读取EXCEL

复制代码
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls,ComObj;

type
  TForm1 = class(TForm)
    btn1: TButton;
    dlgOpen1: TOpenDialog;
    procedure btn1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.btn1Click(Sender: TObject);
var
  ExcelApp,WorkBook: Olevariant;
  ExcelRowCount,i:Integer;
  strName,strAge:string;
begin

  if dlgOpen1.Execute then
  begin

    ExcelApp := CreateOleObject('Excel.Application');
    WorkBook := ExcelApp.WorkBooks.Open(dlgOpen1.FileName);

    ExcelRowCount := WorkBook.WorkSheets[1].UsedRange.Rows.Count;
    //ShowMessage(IntToStr(ExcelRowCount));

    for i:=1 to ExcelRowCount+1 do
    begin
      strName:= ExcelApp.Cells[i,1].Value;
      strAge:= ExcelApp.Cells[i,2].Value;

      {如果有一行为空,则退出}
      if ((strName='') and (strAge='')) then
         exit
      else
      begin
      
        ShowMessage(strName);
        ShowMessage(strAge);

      end;


    end;


  end;

  {最后关闭连接}
  WorkBook.Close;
  ExcelApp.Quit;
  ExcelApp := Unassigned;
  WorkBook := Unassigned;


end;

end.
复制代码

   

  读取出数据,插入数据库的语句,在网上百度到的。

  with query1 do         
  begin          
      close;          
      sql.clear;sql.add(insert into test(name,address) values(:name,:address));
      parambyname('name').asstring := excelx;
      parambyname('address').asstring := excely;
      execsql;         
   end;

 

posted @   春天又来了  阅读(1192)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示