4

我已经安装了某个 python 包(netCDF4),其中包含已编译的代码(扩展模块)。我在 Windows 10 (x64) 下运行 Anaconda 和 python 3.6。从控制台导入模块时,出现以下错误:

In [1]: import netCDF4
---------------------------------------------------------------------------
ImportError                               Traceback (most recent call last)
<ipython-input-1-9588a3d4fb24> in <module>()
----> 1 import netCDF4

C:\Program Files\Anaconda3\lib\site-packages\netCDF4\__init__.py in <module>()
      1 # init for netCDF4. package
      2 # Docstring comes from extension module _netCDF4.
----> 3 from ._netCDF4 import *
      4 # Need explicit imports for names beginning with underscores
      5 from ._netCDF4 import __doc__, __pdoc__

ImportError: DLL load failed: Access is denied.

但是该模块是从管理员帐户完美加载的。

我怀疑某些关键的 DLL 文件被公司范围的安全策略阻止了,这是非常严格的。例如,二进制文件默认被阻止,除非在“程序文件”文件夹中。但是我的 python 发行版和 netCDF4 包已经在这个文件夹中,所以我不知道如何解释这个。Windows 事件查看器中的 AppLocker 日志不显示任何阻止活动。Dependency walker 工具列出的依赖项要么是系统库,要么包含在“程序文件”文件夹中。

如何开始故障排除?我怎样才能知道发生了什么?

4

3 回答 3

2

经过长时间的斗争,我现在有了解决方案。

我以管理员模式启动 python,并使用工具Process Explorer记录加载了哪些 DLL 文件。该import netCDF4语句加载了大约 10 个额外的 DLL 文件。然后我在用户模式下启动 python,并ctypes.WinDLL手动加载这些库中的每一个。然后,我能够查明hdf5.dll导致问题的确切库 ( )。事实证明,它hdf5.dll的权限不完整,因此只能加载管理员权限。

虽然我的问题非常具体,但我希望我的解决方案可以帮助其他人在相关情况下......

于 2018-03-06T11:35:17.950 回答
2

这对我有用:

https://vxlabs.com/2017/12/06/how-to-debug-pyinstaller-dll-pyd-load-failed-issues-on-windows/

在 Windows 上调试 DLL 加载错误时,使用 lucasg 的开源和更现代的旧 Dependency Walker 软件重写。非常重要的是,继续深入研究间接依赖关系,直到找到丢失的 DLL。

在这里下载:https ://github.com/lucasg/Dependencies

也可以在没有管理员权限的情况下使用!

于 2018-11-26T15:38:12.947 回答
-1

这对我有用:关闭防火墙。我用的是360防火墙。在我关掉它之后,一切都很好,花花公子。希望这有帮助

于 2020-06-06T17:46:48.923 回答