- 1
- 0
- 约2.03千字
- 约 4页
- 2025-12-24 发布于山东
- 举报
VBA封装为DLL及调用
使用程序:
1、MicrosoftOfficeExcel2003
2、MicrosoftVisualBasic6.0
案例:在工作表的C1单元格得出A1单元格+B1单元格的值。
设计的VBA代码:
SubTest()
OnErrorResumeNext
Range(C1)=Cells(1,1)+Cells(1,2)
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定义变量VBt
SetVBt=GetObject(,Excel.Application)使VBt表示为EXCEL对象
SetYB=VBt.ActiveSheet使YB表示为EXCEL的当前工作表
注意要在对象前加上YB变量以表示是EXCEL当前工作表的对象
YB.Range(C1)=YB.Cells(1,1).Value+YB.Cells(1,2).Value
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文件
shellRegsvr32/sChr(34)ThisWorkBook.path\VBADLL.dllChr(34)
EndSub
PrivateSubWorkbook_BeforeClose(CancelAsBoolean)关闭文件之前卸载引用的DLL文件
shellRegsvr32/s/uChr(34)ThisWorkBook.path\VBADLL.dllChr(34)
EndSub
/s参数是防止出现确认窗口;/u参数为取消引用。
②DLL文件放在固定文件夹内,如果你有多个XLS文档需要使用到同一个DLL文件,但这些XLS文档又不可能都与DLL文件放在同一个文件夹,则需要将DLL文件放置到一个固定文件夹,这样,只需要将上面的代码ThisWorkBook.path\VBADLL.dll换成一个固定位置即可。
注意:有时间可能出现某些错误,如提示“变量类型未定义”等,可能是引用后改变了文件的位置或改变了文件的名称,即使再重新再改回来也可能会出现这些问题,所以,在正确注册及引用以后,最好不要再去修改这个DLL文件。如果出现问题,重新注册一次,保证注册的DLL文件的位置正确即可。
二、新建一个模块,输入调用DLL文件程序的过程:
SubDLLtest()
DimABCAsNewVBAtest定义ABC为新类,即为DLL文件中的类模块VBAtest
ABC.Test调用DLL中提供的过程,来完成原来在VBA中的功能,起到隐藏代码的效果
SetABC=Nothing释放类资源
EndSub
在工作表中运行DLLtest宏即可实现调用:
综上所述,感觉封装DLL的主要步骤是:
①在VB中引用EXCEL;
②编辑代码(要在对象前面加上定义的EXCEL变量);
③在VBE中引用该DLL文件;
④在VBE的代码中调用DLL中的过程。
您可能关注的文档
- 幼儿园安全例会制度.docx
- 人教版八年级英语上册第一二单元测试题.docx
- 和的组成和加减法.ppt
- 有机化学实验习题及解答.ppt
- 3D打印建筑垃圾试题库及答案.doc
- 5A 景区服务质量等级评定标准单选试题库及答案.doc
- 5A级景区评定标准:服务质量与环境质量试题库及答案.doc
- 5A景区服务质量等级评定标准单选试题库及答案.doc
- 5A景区服务质量等级评定标准单选试题库及答案.docx
- 5G 基站散热器冷锻模具寿命提升试题库及答案.doc
- 七年级语文上册期末模拟试卷1(解析版).docx
- 七年级语文上册期末模拟试卷1(原卷版).docx
- 七年级语文上册期末模拟试卷2(原卷版).docx
- 七年级语文上册期末模拟试卷2(解析版).docx
- 期末测试卷(二)(解析版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
- 期末测试卷(三)(解析版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
- 期末测试卷(二)(原卷版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
- 期末测试卷(三)(原卷版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
- 期末测试卷(一)(原卷版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
- 期末测试卷(一)(解析版)2024—2025学年七年级语文上册期末测试卷(全国版).docx
原创力文档

文档评论(0)