找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 252|回复: 4

[求助]从Excel写数据到Access库 ,能运行,不过有点小问题

[复制链接]
发表于 2009-11-23 11:41:38 | 显示全部楼层 |阅读模式 IP:江苏扬州
uses comobj,excel97,excel2000;
//从Excel写数据到Access库
prodedure ExcelToMdb(EXLfile:string;);
var
sheet,XLApp,workbook : variant;
iRow,MaxRow:integer;
begin
screen.Cursor:=crHourGlass;
try
//创建对象
XLApp:=createOleObject('Excel.Application');
XLApp.displayAlerts:=false;
XLApp.ScreenUpdating:=false;
XLApp.WorkBooks.Add(EXLfile);
workbook := XLApp.workbooks[1];
sheet:=workbook.worksheets[1];
//sheet:=XLApp.WorkBooks[1].worksheets[1];


//取得最大行数 maxRow
XLApp.ActiveCell.SpecialCells(xlLastCell).Select;
maxRow:=XLApp.ActiveCell.Row; //最大行数
//写数据到Access库
ADOTable1.open;
for iRow:=2 to MaxRow do
begin
ADOTable1.Append ;
ADOTable1.fieldByName('ID').asInteger:=
strToInt(sheet.cells[iRow,1]);
ADOTable1.fieldByName('code').asString:=sheet.cells[iRow,2]; //编码
ADOTable1.fieldByName('name').asString:=sheet.cells[iRow,3]; //名称
ADOTable1.post;
end;
finally
if not VarIsEmpty(XLApp) then begin //释放对象
XLApp.displayAlerts:=false;
XLApp.ScreenUpdating:=true;
XLApp.quit;
end;
screen.Cursor:=crDefault;
end;
end;
//=================== 其他一些属性方法 ===============//
curRow:=XLApp.ActiveCell.Row; //当前行数
XLApp.displayAlerts:=false; //运行宏时是否显示警告和消息
XLApp.ScreenUpdating:=false; //屏幕更新功能,提高速度;
//结束运行后,ScreenUpdating 设回到 True
XLApp.run('macroName',params...)//运行宏
workbook.save ;
workBook.SaveAs(AFileName,xlNormal,'','',False,False);
//=====================================


上面这段程序,EXLfile可以用opendialog控件来打开个excel文件,把opendialgo1.filename赋给EXLfile。该段程序
要求access数据库中不设关键字段,如果要设则需要稍微做点改动。程序的问题是最后1段“释放对象”,程序运行后,只要导入access成功,桌面的excel就不能正常运行,据我判断,并没成功释放对象,而在关闭程序后,excel还在调用中,小弟不才,不知道最后一段该如何改进,请大虾们指点指点。
发表于 2009-11-23 11:41:41 | 显示全部楼层 IP:江苏扬州
已解决
回复

使用道具 举报

发表于 2009-11-23 11:41:44 | 显示全部楼层 IP:江苏扬州
你的对象只是在异常时候被释放,所以也要在程序运行完毕时候释放。

我以前用的是ole对象实现插入SQL Server的。没有用这三个控件。哈哈
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-29 13:25 , Processed in 0.297876 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表