浅谈64位excel里面怎么调用32位的dll/OCX

大家应该遇到过64位office在vba里无法调用32位dll的问题。最近看到别人碰到了类似的问题。我就来啰嗦几句。

微软公司的官方网站针对这个问题描述如下:

在64位的windows系统中,一个64位进程不能加载一个32位dll,同理一个32位进程也不能加载一个64位dll。但是,64位windows支持64位和32位进程(包括本机或跨机)间进程间通信(RPC)。在64位windows中,一个进程外32位COM服务器能够与64位客户端进行通信,同样一个进程外64位COM服务器也能与32位客户端进行通信。因此,如果你有一个32位COM无法识别的DLL,你可以将它封装到一个进程外COM服务器中并在一个64位进程中用COM配置调用DLL。

上面那一段我自己来理解就是 dll/ocx是个单性恋,而进程外的com服务器是个双性恋,32/64通杀。

就拿之前我自己使用的scriptcontrol(在msscript.ocx里)只能用于32位的excel.今天我们就来解决怎么在64位的excel上使用官方的这个dll.

1.首先用VB6创建一个32位的com服务器。就是Activex exe这玩意。

  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 无法注册dll/ocx,可能是因为以下原因: 1. 没有管理员权限:请以管理员身份运行命令提示符或注册表编辑器。 2. 缺少依赖项:某些dll/ocx可能需要其他文件才能正常注册。请确保所有依赖项都已安装并可用。 3. 文件已损坏:如果dll/ocx文件已损坏,则无法注册。请尝试重新安装软件或修复文件。 4. 注册表错误:如果注册表中存在错误,则可能无法注册dll/ocx。请使用注册表编辑器修复错误。 如果以上方法都无法解决问题,请尝试联系软件开发商或操作系统厂商获取更多帮助。 ### 回答2: Regsvr32是一种命令行实用程序,可用于向Windows注册DLL文件和ActiveX控件(OCX)文件。Windows操作系统将动态链接库(DLL)限制为只能进行请求的操作,以增强系统的安全性。存在许多原因可能导致Regsvr32无法注册DLLOCX文件,下面是一些可能的原因和解决办法: 1. 访问拒绝:这种情况可以出现在没有使用管理员权限运行命令提示符时。为了解决这个问题,可以尝试使用管理员权限运行命令提示符并重试注册。 2. 缺少依赖项:某些DLL需要其他DLL来完成其任务。如果缺少这些依赖项,则会出现这种情况。通常,可以通过手动安装缺少的依赖项来解决此问题。 3. 文件损坏:如果DLLOCX文件在下载或安装期间被损坏,则无法注册。重新下载资源并重试注册可能会解决问题。 4. 注册表问题:注册表是Windows操作系统中关键的组成部分之一。如果出现注册表损坏或其他问题,则Regsvr32可能无法注册DLLOCX文件。可以尝试运行修复注册表的工具来解决问题。 5. 版本冲突:某些DLLOCX文件需要与特定Windows版本兼容。如果尝试在不受支持的操作系统版本上注册文件,则可能会出现问题。确保您的操作系统与所需文件兼容。 总之,Regsvr32无法注册DLLOCX文件可能是多种问题的结果,因此需要在确定错误源后采取适当的解决措施。建议仔细查看错误消息并尝试使用适当的辅助工具来解决问题。 ### 回答3: 当使用regsvr32命令注册DLL/OCX文件时,有时会遇到无法注册的情况。造成这种情况的原因可能有很多, 主要原因有以下几个: 1.权限不足:有时需要管理员权限来执行regsvr32命令,如果没有以管理员身份运行命令提示符或PowerShell,则会出现权限不足的错误。 2.文件不存在或已损坏:如果没有正确路径或文件名,或DLL/OCX文件已经损坏,则会导致无法注册DLL/OCX文件。 3.版本不匹配:如果DLL/OCX文件的版本与当前系统不兼容,则会导致无法注册文件。 4.注册表损坏:注册表是Windows系统中用于存储系统配置和安装信息的数据库。如果注册表损坏,则无法注册DLL/OCX文件。 5.病毒感染:有些病毒可能会破坏系统文件,包括DLL/OCX文件。如果系统已经感染病毒,则可能无法注册DLL/OCX文件。 要解决无法注册DLL/OCX文件的问题,可以采取以下步骤: 1.以管理员身份运行regsvr32命令。 2.确保文件存在并且没有损坏。可以通过检查文件路径和文件名是否正确,或者在另一台计算机上运行相同的文件来确认。 3.检查DLL/OCX文件的版本是否与当前系统兼容。可以使用属性菜单查看文件的详细信息。 4.使用系统文件检查器(SFC)来修复任何损坏的系统文件。 5.运行杀毒软件来检查是否存在病毒感染,并清除任何病毒文件。 希望以上解释能够帮助您解决无法注册DLL/OCX文件的问题。如果仍遇到问题,请咨询系统管理员或联系技术支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值