我在安装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。


当前回答

在Windows上, 您可能希望安装Psycopg的Windows端口,Psycopg的文档中推荐这样做。

其他回答

综上所述,我也遇到了同样的问题。在阅读了大量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。

在Gentoo上,您必须执行以下操作

# Install postgresql client libraries
sudo emerge postgresql-base

我在Oracle Linux 7.9上安装这个库时遇到了很大的问题。无论我在做什么,我都无法通过pip安装psycopg2。所以我决定通过yum使用以下命令安装它:

yum install http://mirror.centos.org/centos/7/os/x86_64/Packages/python-psycopg2-2.5.1-4.el7.x86_64.rpm

通过这个命令安装psycopg2,我可以通过ansible创建postgres用户,DB。(我知道这是第六十个答案,但我希望这个答案仍然可以帮助到一些人)。

你安装python-dev了吗? 如果已经安装了libpq-dev,也可以尝试安装libpq-dev

sudo apt-get install libpq-dev python-dev

摘自文章:如何在virtualenv下安装psycopg2

对于那些没有在本地安装Postgresql并希望将其作为Docker容器运行的人。您应该使用psycopg2-binary。