我有一个类似于ImportError: DLL load failed : - when trying to import psycopg2 library
的问题我正在尝试使用Visual Studio 2008(vc9)构建的Python 2.6.5运行psycopg2。我收到这个错误:
from _psycopg import BINARY, NUMBER, STRING, DATETIME, ROWID
ImportError: DLL load failed: The operating system cannot run %1.
来自PostGres 8.4的libpg.dll就在路径中。如果我使用vc6构建的python构建psycopg2,它会 运行正常。但问题是我需要它来使用vc9构建的Python。
我引用的页面使用的是旧版本。当我尝试构建版本2.12.0(甚至2.10.0)时, 我收到这个错误:
C:\Program Files\Microsoft Visual Studio 9.0\VC\BIN\cl.exe /c /nologo /Ox /MD /W
3 /GS- /DNDEBUG -DPSYCOPG_DEFAULT_PYDATETIME=1 "-DPSYCOPG_VERSION=\"2.0.10 (dt d
ec ext pq3)\"" -DPG_VERSION_HEX=0x080401 -DPSYCOPG_EXTENSIONS=1 -DPSYCOPG_NEW_BO
OLEAN=1 -DHAVE_PQFREEMEM=1 -DHAVE_PQPROTOCOL3=1 -IC:\Python26\include -IC:\Pytho
n26\PC -I. -Ic:/apps/POSTGR~1/8.4/include -Ic:/apps/POSTGR~1/8.4/include/server
/Tcpsycopg\connection_int.c /Fobuild\temp.win32-2.6\Release\psycopg\connection_i
nt.obj /Wp64
cl : Command line warning D9035 : option 'Wp64' has been deprecated and will be
removed in a future release
connection_int.c
psycopg\connection_int.c(70) : error C2143: syntax error : missing ';' before 't
ype'
psycopg\connection_int.c(71) : error C2065: 'notice' : undeclared identifier
psycopg\connection_int.c(71) : warning C4047: '=' : 'int' differs in levels of i
ndirection from 'connectionObject_notice *'
psycopg\connection_int.c(73) : error C2065: 'notice' : undeclared identifier
psycopg\connection_int.c(73) : warning C4047: '!=' : 'int' differs in levels of
indirection from 'void *'
以及之后......看看C代码,没有条件代码 包装struct connectionObject_notice的定义,所以我没有 看看什么会触发这个错误。
最后,上面帖子中的一张海报提到了“PG6000”。那是什么?
答案 0 :(得分:2)
也许你应该安装Windows SDK 7.0。
我有vs2005 / vs2008 / vc2010和我系统中安装的一些Windows SDK,
当我安装psycopg2-2.4.2 python包时使用“python setup.py install”,
它提示我需要“mt.exe”;
所以我将“C:\ Program Files(x86)\ Microsoft SDKs \ Windows \ v7.0A \ Bin”添加到路径,
然后它会建立好。但python -c“import psycopg2”sill失败,所以我将PostgreSQL客户端安装路径:“... \ PostgreSQL \ 8.4 \ bin”添加到系统路径,然后全部运行正常。