明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 892|回复: 3

VB创建输出函数的DLL的方法-百度下载,目的供VBA调用

[复制链接]
发表于 2018-7-6 11:11:30 | 显示全部楼层 |阅读模式
由于VBA代码的简单、局限性,有些复杂功能无法实现,比如VB6里可创建对话框数组,但VBA里没有这个功能。可借助于VB来实现,通过DLL传递参数给VBA。
这里分享一个本人从网上搜罗到的VB创建DLL的有效方法。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2018-7-19 13:14:22 | 显示全部楼层
这些没营养的、十几年前的东西,实在没意思
回复 支持 1 反对 0

使用道具 举报

发表于 2018-7-18 19:28:06 | 显示全部楼层
就这几个字,没必要放附件里,帮你直接贴出来:

VB创建输出函数的DLL的方法-百度下载
VB中创建的DLL只是COM组件,无法作为输出函数的DLL,其实这只是个错误的说法。其实MS非常狡猾,如果你是个VB疯狂发烧友的话,应该早就狂试出这种可以创建输出函数的DLL的方法。   
      VB编译文件实际上采取了两次编译的方法,首先是调用C2.exe产生*.OBJ文件,然后调用Link.EXE连接。如果在LINK的时候添加EXPORT选项,实际上是可以输出函数的。但是,在VB的工程选项中将这些屏蔽了。而且过分的是:VB在Build完成后会将OBJ文件删除,这样就无法手动通过Link来创建我们需要的DLL了。不过我找到一个比较龌鹾的变通的方法,就是先创建一个Exe工程,在Form_Load事件里面写下面的语句:   
    Sub Main   
     If MsgBox("哈哈", vbOKCancel) = vbOK Then   
     Shell "link2.exe " & Command$   
     End If   
    End Sub   
      
    然后编译为LinkTemp.EXE,接下来将LINK.EXE改名为Link2.exe,将LinkTemp.EXE改名为Link.EXE。这样在VB调用Link.EXE时会弹出对话框,处理就会中断。这时就可以有机会将OBJ文件拷贝出来了。   
     然后我创建了一个ActiveX DLL工程,在这个工程里面添加一个Module并创建一个Public函数mathadd:   
      
    Public Function mathadd(ByVal a As Long, ByVal b As Long) As Long   
     mathadd = a + b   
    End Function   
      
     编译这个工程,在Link的时候就会中断。然后把创建的Class1.obj、Module1.obj、Project1.obj备份出来。   
     然后就可以调用Link2.exe连接OBJ到DLL了,我的连接代码是:   
      
    Link2.exe "e:\vbdll\Class1.obj" "e:\vbdll\Module1.obj" "e:\vbdll\Project1.obj" "E:\Program Files\Microsoft Visual Studio\VB98\VBAEXE6.LIB" /ENTRY:__vbaS /EXPORT:mathadd /OUT:"e:\vbdll\ProjectOK.dll" /BASE:0x11000000 /SUBSYSTEM:WINDOWS,4.0 /VERS   
      
     注意里面的/ENTRY和/EXPORT开关,/EXPORT开关声明了输出函数mathadd。这样就大功告成了,可以被其他语言引入,例如在VB中,只需要:   
      
    Private Declare Function mathadd Lib "e:\vbdll\ProjectOK.dll" (ByVal a As Long, ByVal b As Long) As Long  
 楼主| 发表于 2018-7-20 23:54:50 | 显示全部楼层
“高端”人士与“专业打广告的“请绕行!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-29 02:48 , Processed in 0.147754 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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