VBA封装为DLL及调用.pdf

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

VBA封装为DLL及调用

使用程序:

1、MicrosoftOfficeExcel2003

2、MicrosoftVisualBasic6.0

案例:在工作表的C1单元格得出A1单元格+B1单元格的值。

设计的VBA代码:

SubTest()

OnErrorResumeNextOnErrorResumeNext

EndSub

第一部分、使用VB6.0制作DLL文件

一、启动VB6.0,新建一个ActiveXDLL工程:

二、引用:在VB中对Excel的引用

不同版本的EXCEL在“引用”窗口里显示的版本号也不同:

EXCEL2000(MicrosoftOffice9.0)

EXCEL2002(MicrosoftOffice10.0),即ExcelXP

EXCEL2003(MicrosoftOffice11.0)

EXCEL2007(MicrosoftOffice12.0)

EXCEL2010(MicrosoftOffice14.0)

EXCEL2013(MicrosoftOffice15.0)

三、修改ActiveXDLL的工程名称和类模块名称

四、编写代码:

在代码窗口输入代码,过程名称为Test:

SubTest()

OnErrorResumeNext

DimVBt,YB定义变量VBtVBt

使VBt表示为EXCEL对象

SetYB=VBt.ActiveSheet使YB表示为EXCEL的当前工作表

注意要在对象前加上YB变量以表示是EXCEL当前工作表的对象

EndSub

五、设置工程属性(为使开发的程序更规范,可以对工程属性加以描述【非必要

设置,可以省略】):

六、保存工程、测试、生成DLL文件:

1、保存工程:保存本工程以作为将来修改代码和升级程序的需要;

2、测试工程:执行快捷工具栏上的“启动”按钮,检查是否存在错误;

3、生成DLL文件:制作DLL文件。

第二部分、调用DLL文件

一、在VBE中调用DLL文件

调用DLL文件,要分两步走:先注册DLL,再引用DLL。

1、注册DLL(使之放在可引用的列表上):

注册DLL也可以使用代码来做,但那样比较复杂,也存在很多问题,建议一般使

用手工来注册。

(这里应该先设计好DLL文件放在硬盘的位置,因为后面引用DLL文件的代码也

应该是指向这个位置的。)

先打开EXCEL,再打开“VisualBasic编辑器”

2、引用DLL(这样每次打开打开文件时,就不必再去那个引用列表里打个勾了)

①DLL文件放在与EXCEL文件同一个文件夹内

在ThisWorkbook中添加如下代码:

PrivateSubWorkbook_Open()打开文件时加载要引用的DLL文件

EndSub

PrivateSubWorkbook_BeforeClose(CancelAsBoolean)关闭文件之前卸载引用的DLL文件

EndSub

/s参数是防止出现确认窗口;/u参数为取消引用。

②DLL文件放在固定文件夹内,如果你有多个XLS文档需要使用到同一个DLL文件,但这些

XLS文档又不可能都与DLL文件放在同一个文件夹,则需要将DLL文件放置到一个固定文件

夹,这样,只需要将上面的代码夹,这样,只需要将上面的代码换成一个固定位置即可。

注意:有时间可能出现某些错误,如提示“变量类型未定义”等,可能是引用后改变了文件的

位置或改变了文件的名称,即使再重新再改回来也可能会出现这些问题,所以,在正确注册及

引用以后,最好不要再去修改这个DLL文件。如果出现问题,重新注册一次,保证注册的

DLL文件的位置正确即可。

二、新建一个模块,输入调用DLL文件程序的过程:

SubDLLtest()

DimABCAsNewVBAtest定义ABC为新类,即为DLL文件中的类模块VBAtest

ABC.Test调用DLL中提供的过程,来完成原来在VBA中的功能,起到隐藏代码的效果

SetABC=Nothin

您可能关注的文档

文档评论(0)

***** + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档