我在安装psycopg2时遇到了麻烦。当我尝试pip安装psycopg2时,我得到以下错误:
Error: pg_config executable not found.
Please add the directory containing pg_config to the PATH
or specify the full executable path with the option:
python setup.py build_ext --pg-config /path/to/pg_config build ...
or with the pg_config option in 'setup.cfg'.
----------------------------------------
Command python setup.py egg_info failed with error code 1 in /tmp/pip-build/psycopg2
但问题是pg_config实际上在我的PATH中;它运行起来没有任何问题:
$ which pg_config
/usr/pgsql-9.1/bin/pg_config
我尝试将pg_config路径添加到setup.cfg文件中,并使用我从他们的网站(http://initd.org/psycopg/)下载的源文件构建它,我得到了以下错误消息!
Error: Unable to find 'pg_config' file in '/usr/pgsql-9.1/bin/'
但它确实在那里!!
我对这些错误感到困惑。有人能帮忙吗?
顺便说一下,我sudo所有的命令。而且我使用的是RHEL 5.5。
你必须安装libpq-dev/ PostgreSQL -libs,这是编译C程序链接到libpq库的头文件和静态库,以便与PostgreSQL数据库后端通信。
在Arch上运行:
$ sudo pacman -S postgresql-libs
在Debian和Ubuntu上:
$ sudo apt-get install libpq-dev
在Mac OS X上:
$ brew install postgresql
在Red Hat/CentOS/Fedora上:
$ sudo yum install postgresql-devel
我很确定你也经历过和我一样的“问题”,因此我将为你提供一个极其简单的解决方案……
在你的例子中,你需要添加到$ path(或作为命令参数)的实际路径是:
/usr/pgsql-9.1/bin/pg_config
not
/usr/pgsql-9.1/bin
例如,如果你随后运行python setup.py脚本,你会像这样运行它:
python setup.py build_ext --pg-config /usr/pgsql-9.1/bin/pg_config build
也许太晚了,但仍然是最简单的解决办法。
后来编辑:
在进一步的测试中,我发现如果最初在表单中添加路径到pg_config
/usr/pgsql-9.1/bin
(...../bin后面没有/pg_config)并运行PIP install命令,它将工作。
然而,如果你决定按照指示运行python setup.py,你必须在.....之后用/pg_config指定路径/ bin。
python setup.py build_ext --pg-config /usr/pgsql-9.1/bin/pg_config build
综上所述,我也遇到了同样的问题。在阅读了大量stackoverflow的帖子和在线博客后,最终对我有效的解决方案是:
1)在安装psycopg2之前,应该先安装PostgreSQL(开发版或任何稳定版)。
2) pg_config文件(该文件通常位于PostgreSQL安装文件夹的bin文件夹中)PATH必须在安装psycopg2之前显式设置。在我的例子中,PostgreSQL的安装路径是:
/opt/local/lib/postgresql91/
所以为了显式地设置pg_config文件的PATH,我在我的终端输入了以下命令:
PATH=$PATH:/opt/local/lib/postgresql91/bin/
该命令确保当您尝试pip安装psycopg2时,它这次将自动找到pg_config的PATH。
我还在我的博客上发布了一个完整的错误跟踪和解决方案,你可能想要参考。它适用于Mac OS X,但pg_config PATH问题是通用的,也适用于Linux。