欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

解决 pynvml 报错 NVML Shared Library Not Found / WinError 126

程序员文章站 2022-04-16 08:52:49
...

pynvml包直接在Windows系统上安装可能会报出模块找不到的错误,本文记录解决方法。

问题复现

在Windows中调用 pynvml.nvmlInit()时出错:

解决 pynvml 报错 NVML Shared Library Not Found / WinError 126

错误信息:

 File "E:\Program_Files\Annoconda\lib\site-packages\pynvml\nvml.py", line 731, in _load_nvml_library
    nvml_lib = CDLL(os.path.join(os.getenv("ProgramFiles", "C:/Program Files"), "NVIDIA Corporation/NVSMI/nvml.dll"))
  File "E:\Program_Files\Annoconda\lib\ctypes\__init__.py", line 356, in __init__
    self._handle = _dlopen(self._name, mode)
OSError: [WinError 126] 找不到指定的模块。

问题分析

  • 在源代码文件 numl.py 中 731 行附近:
if (sys.platform[:3] == "win"):
    # cdecl calling convention
    # load nvml.dll from %ProgramFiles%/NVIDIA Corporation/NVSMI/nvml.dll
    nvml_lib = CDLL(os.path.join(os.getenv("ProgramFiles", "C:/Program Files"), "NVIDIA Corporation/NVSMI/nvml.dll"))
else:
    # assume linux
    nvml_lib = CDLL("libnvidia-ml.so.1")

可以看到模块在尝试寻找 C:/Program Files/NVIDIA Corporation/NVSMI/nvml.dll 文件,如果你的nvml.dll文件不在这就会报错。

解决方案

知道问题的原因,排除故障有两种方案,但都需要知道当前的vnml.dll文件在哪。

确定 nvidia-smi.exe 位置
  • 打开cmd,输入命令:
where nvidia-smi

会返回当前系统的 nvidia-smi.exe的位置 (前提是当前cuda安装正常,可以使用nvidia-smi)

解决 pynvml 报错 NVML Shared Library Not Found / WinError 126

  • 去相应位置查看,发现vnml.dll文件和他在一起,所以只要将代码中路径指向它就行了。

方案1: 修改源码:

  • 修改numl.py 中第 731 行代码:
nvml_lib = CDLL(os.path.join(os.getenv("ProgramFiles", "C:/Program Files"), "NVIDIA Corporation/NVSMI/nvml.dll"))

改为你自己的路径:

nvml_lib = CDLL(r"C:\Windows\System32\nvml.dll")

注意反斜杠路径需要在前面加 r

方案2: 为源码创建运行环境

  • 源码不会出错,错的是我们自己的环境,改过来就是了。

  • 创建文件夹C:\Program Files\NVIDIA Corporation\NVSMI

  • nvml.dll文件放在文件夹里

运行示例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TE2HNg9i-1604665928735)(https://photos.zywvvd.com/images_matrixtime/20201106162159.png)]

参考资料:

  • https://blog.csdn.net/com_fang_bean/article/details/107988018