ImportError: dlopen(/Users/cc/python_envs/envname_01_cheoa_pc_test/lib/python3.9/site-packages/pyodbc.cpython-39-darwin.so, 0x0002): Library not loaded: /usr/local/opt/unixodbc/lib/libodbc.2.dylib Referenced from: <9820BF4A-872E-3566-A1CA-2902C9CCBCE4> /Users/cc/python_envs/envname_01_cheoa_pc_test/lib/python3.9/site-packages/pyodbc.cpython-39-darwin.so Reason: tried: '/usr/local/opt/unixodbc/lib/libodbc.2.dylib' (no such file), '/System/Volumes/Preboot/Cryptexes/OS/usr/local/opt/unixodbc/lib/libodbc.2.dylib' (no such file), '/usr/local/opt/unixodbc/lib/libodbc.2.dylib' (no such file), '/usr/lib/libodbc.2.dylib' (no such file, not in dyld cache)
时间: 2023-07-06 11:36:30 浏览: 326
这个错误提示表明 pyodbc 在加载 `libodbc.2.dylib` 库时失败了,因为找不到这个库文件。要解决这个问题,你需要检查以下几点:
1. 确认你已经正确安装了 unixODBC 库。
2. 检查 `libodbc.2.dylib` 库文件是否存在于 `/usr/local/opt/unixodbc/lib/` 目录中。如果不存在,可能是由于 unixODBC 安装不完整或者未安装导致的。你可以尝试重新安装 unixODBC 库,或者手动下载 `libodbc.2.dylib` 库文件,并将其放置到 `/usr/local/opt/unixodbc/lib/` 目录中。
3. 确认你的系统环境变量中是否包含了 unixODBC 库的路径。你可以使用以下命令检查:
```
echo $DYLD_LIBRARY_PATH
```
如果输出结果中不包含 `/usr/local/lib` 路径,可以尝试将其添加到环境变量中:
```
export DYLD_LIBRARY_PATH=/usr/local/lib:$DYLD_LIBRARY_PATH
```
然后重新加载环境变量:
```
source ~/.bash_profile
```
4. 如果你在虚拟环境中运行代码,你需要确保在虚拟环境的 `bin/activate` 脚本中也添加了上述命令,将 `/usr/local/lib` 路径添加到 `DYLD_LIBRARY_PATH` 环境变量中。
如果你按照上述步骤仍然无法解决问题,你可以尝试重新安装 pyodbc 库,或者在 Stack Overflow 等技术社区上寻求帮助。
阅读全文