DLL相对路径:DLL文件未找到

http://blog.163.com/shikang999@126/

 

问题:在使用VBA时,有时我们会调用外部的Dll文件,而此DLL文件会随着打包程序的发放而放在不同的目录,由于Dll文件就放置在执行文件的一个相对路径下,这时在程序内部定义调用Dll文件时,其定义的路径为相对路径.然而很多时候程序并不能识别到定义的Dll文件路径。如何让程序自动识别相对路径,即为本问题所在!

 

解决:设置指定路径为当前系统目录即可.使用的API函数为SetCurrentDirectoryA

 

例子:

 

//下面的例子是,在VBA要执行的代码里,需要调用外部Dll文件"FEM.Dll"里的函数TestSub,而外部这Dll文件放在当前激活文件目录下"\Lib\FEM.Dll",在执行TestSub函数前,直接使用SetCurrentDirectoryA设置当前目录即可.看代码:

 

Public Declare Function SetCurrentDirectory Lib "kernel32" Alias "SetCurrentDirectoryA" (ByVal lpPathName As String) As Long '注意这是API函数的申明

Declare Sub TestSub Lib ".\Lib\FEM.dll"(ByVal a As Integer,ByVal b As Integer) '注意当中相对路径的写法

Sub RoundedRectangle1_Click()

SetCurrentDirectory(Application.ActiveWorkbook.Path) '很重要,设置当前激活目录

Call TestSub(1,2) '调用函数示例

End Sub

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 C 语言中,可以使用以下函数来加载 DLL 文件: ```c #include <windows.h> HINSTANCE LoadLibrary(LPCTSTR lpFileName); ``` 其中,`lpFileName` 参数是 DLL 文件路径。你可以使用相对路径或绝对路径来指定它。 如果你想使用相对路径来加载 DLL 文件,可以使用以下方法: 1. 获取 DLL 文件所在的目录路径。 ```c #include <stdio.h> #include <stdlib.h> #include <windows.h> int main(void) { char dllPath[MAX_PATH]; GetModuleFileName(NULL, dllPath, MAX_PATH); // 获取当前程序的路径 char *p = strrchr(dllPath, '\\'); // 找到最后一个 '\' 的位置 if (p != NULL) { *(p + 1) = '\0'; // 在最后一个 '\' 后面加上 '\0' } printf("%s", dllPath); // 输出 DLL 文件所在的目录路径 return 0; } ``` 2. 将 DLL 文件路径设置为相对于 DLL 所在的目录路径相对路径。 ```c #include <windows.h> int main(void) { char dllPath[MAX_PATH] = "mydll.dll"; // 相对路径 HINSTANCE hDll = LoadLibrary(dllPath); if (hDll == NULL) { // 加载 DLL 文件失败 return 1; } // 使用 DLL 文件中的函数 // ... FreeLibrary(hDll); return 0; } ``` 在上面的代码中,我们假设 DLL 文件和程序在同一个目录下,因此将 DLL 文件路径设置为相对路径 `"mydll.dll"`。 如果 DLL 文件和程序不在同一个目录下,你需要根据实际情况来设置相对路径。例如,如果 DLL 文件在程序的上一级目录下的 `lib` 子目录中,你可以将 DLL 文件路径设置为相对路径 `"..\lib\mydll.dll"`。 希望这些信息对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yueliang2100

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值