乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 104|回复: 3

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

[复制链接]

11

主题

23

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

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

本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

23

主题

561

帖子

13

银币

中流砥柱

Rank: 25

铜币
653
发表于 2018-7-19 13:14:00 | 显示全部楼层
这些没营养的、十几年前的东西,实在没意思
回复

使用道具 举报

5

主题

39

帖子

4

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
59
发表于 2018-7-18 19:28:00 | 显示全部楼层
就这几个字,没必要放附件里,帮你直接贴出来:
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  
回复

使用道具 举报

11

主题

23

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
67
发表于 2018-7-20 23:54:00 | 显示全部楼层
“高端”人士与“专业打广告的“请绕行!!!
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-13 03:26 , Processed in 0.601467 second(s), 65 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表