首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 冲浪宝典-> 联络聊天
实现VB与EXCEL的无缝连接-.NET教程,VB.Net语言
作者:网友供稿 点击:800
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 
如何实现vb与excel的无缝连接

  vb是常用的应用软件开发工具之一,由于vb的报表功能有限,而且一但报表格式发生变化,就得相应修改程序,给应用软件的维护工作带来极大的不便。因此有很多程序员现在已经充分利用execl的强大报表功来实现报表功能。但由于vb与excel由于分别属于不同的应用系统,如何把它们有机地结合在一起,是一个值得我们研究的课题。

  一、 vb读写excel表:

  vb本身提自动化功能可以读写excel表,其方法如下:

  1、在工程中引用microsoft excel类型库:

  从"工程"菜单中选择"引用"栏;选择microsoft excel 9.0 object library(excel2000),然后选择"确定"。表示在工程中要引用excel类型库。

  2、在通用对象的声明过程中定义excel对象:

dim xlapp as excel.application
dim xlbook as excel.workbook
dim xlsheet as excel.worksheet

  3、在程序中操作excel表常用命令:

set xlapp = createobject("excel.application") 创建excel对象
set xlbook = xlapp.workbooks.open("文件名") 打开已经存在的excel工件簿文件
xlapp.visible = true 设置excel对象可见(或不可见)
set xlsheet = xlbook.worksheets("表名") 设置活动工作表
xlsheet.cells(row, col) =值 给单元格(row,col)赋值
xlsheet.printout 打印工作表
xlbook.close (true) 关闭工作簿
xlapp.quit 结束excel对象
set xlapp = nothing 释放xlapp对象
xlbook.runautomacros (xlautoopen) 运行excel启动宏
xlbook.runautomacros (xlautoclose) 运行excel关闭宏

  4、在运用以上vb命令操作excel表时,除非设置excel对象不可见,否则vb程序可继续执行其它操作,也能够关闭excel,同时也可对excel进行操作。但在excel操作过程中关闭excel对象时,vb程序无法知道,如果此时使用excel对象,则vb程序会产生自动化错误。形成vb程序无法完全控制excel的状况,使得vb与excel脱节。

  二、 excel的宏功能:

  excel提供一个visual basic编辑器,打开visual basic编辑器,其中有一工程属性窗口,点击右键菜单的"插入模块",则增加一个"模块1",在此模块中可以运用visual basic语言编写函数和过程并称之为宏。其中,excel有两个自动宏:一个是启动宏(sub auto_open()),另一个是关闭宏(sub auto_close())。它们的特性是:当用excel打含有启动宏的工簿时,就会自动运行启动宏,同理,当关闭含有关闭宏的工作簿时就会自动运行关闭宏。但是通过vb的自动化功能来调用excel工作表时,启动宏和关闭宏不会自动运行,而需要在vb中通过命令xlbook.runautomacros (xlautoopen)和xlbook.runautomacros (xlautoclose) 来运行启动宏和关闭宏。

  三、 vb与excel的相互勾通:

  充分利用excel的启动宏和关闭宏,可以实现vb与excel的相互勾通,其方法如下:

  在excel的启动宏中加入一段程序,其功能是在磁盘中写入一个标志文件,同时在关闭宏中加入一段删除此标志文件的程序。vb程序在执行时通过判断此标志文件存在与否来判断excel是否打开,如果此标志文件存在,表明excel对象正在运行,应该禁止其它程序的运行。如果此标志文件不存在,表明excel对象已被用户关闭,此时如果要使用excel对象运行,必须重新创建excel对象。

  四、举例:

  1、在vb中,建立一个form,在其上放置两个命令按钮,将command1的caption属性改为excel,command2的caption属性改为end。然后在其中输入如下程序:

dim xlapp as excel.application 定义excel类
dim xlbook as excel.workbook 定义工件簿类
dim xlsheet as excel.worksheet 定义工作表类
private sub command1_click() 打开excel过程
 if dir("d:\temp\excel.bz") = "" then 判断excel是否打开
  set xlapp = createobject("excel.application") 创建excel应用类
  xlapp.visible = true 设置excel可见
  set xlbook = xlapp.workbooks.open("d:\temp\bb.xls") 打开excel工作簿
  set xlsheet = xlbook.worksheets(1) 打开excel工作表
  xlsheet.activate 激活工作表
  xlsheet.cells(1, 1) = "abc" 给单元格1行驶列赋值
  xlbook.runautomacros (xlautoopen) 运行excel中的启动宏
 else
  msgbox ("excel已打开")
 end if
end sub

private sub command2_click()
 if dir("d:\temp\excel.bz") <> "" then 由vb关闭excel
  xlbook.runautomacros (xlautoclose) 执行excel关闭宏
  xlbook.close (true) 关闭excel工作簿 
  xlapp.quit 关闭excel
 end if
 set xlapp = nothing 释放excel对象
 end
end sub


  2、在d盘根目录上建立一个名为temp的子目录,在temp目录下建立一个名为"bb.xls"的excel文件。

  3、在"bb.xls"中打开visual basic编辑器,在工程窗口中点鼠标键选择插入模块,在模块中输入入下程序存盘:


sub auto_open()
 open "d:\temp\excel.bz" for output as #1 写标志文件
 close #1
end sub
sub auto_close()
 kill "d:\temp\excel.bz" 删除标志文件
end sub

  4、运行vb程序,点击excel按钮可以打开excel系统,打开excel系统后,vb程序和excel分别属两个不同的应用系统,均可同时进行操作,由于系统加了判断,因此在vb程序中重复点击excel按钮时会提示excel已打开。如果在excel中关闭excel后再点excel按钮,则会重新打开excel。而无论excel打开与否,通过vb程序均可关闭excel。这样就实现了vb与excel的无缝连接。




文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Java Unicode转义字符的小小研究-JSP教程,Java技巧及代码
·实现VB与EXCEL的无缝连接-.NET教程,VB.Net语言
·在ASP.NET里通过URL传递参数得到乱码的解决方法-ASP教程,ASP应用
·实例讲解:Java中的SOAP技术-JSP教程,Java技巧及代码
·Session过期问题-ASP教程,ASP应用
·设计模式笔记-抽象工厂模式-.NET教程,评论及其它
·JSP标准标记库促进了网页的开发-JSP教程,Jsp/Servlet
·在Remoting Server上取得Remoting Client的IP地址-ASP教程,ASP应用
·使用JSP标记库校验用户输入-JSP教程,Jsp/Servlet
·c#中DataGrid的数据新增编辑删除操作代码-.NET教程,数据库应用
最新文章
·xp也能享受vista readyboost闪存加速_windows xp
·c# 3.0新特性系列:隐含类型var_c#教程
·如此做google广告,月赚10万美金不成问题_网赚技巧
·王通:个人博客的赚钱之道_网赚技巧
·这一年来风风雨雨-再访中客宋陈磊_站长访谈
·个人网站的定位推广和赚钱-访中国建站站长_站长访谈
·祥瑞网方文春:从800元到6000万元_站长访谈
·行业类、专业性成功网站给个人站长的启示_站长访谈
·网站推广 新招老招齐用上_站长心得
·widnows vista工具栏添加快速启动tabletpc图标_windows vista
相关主题
西部数码虚拟主机

友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 自助建站
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
发表评论 打印  刷新     关闭