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


当前回答

这里,为了OS X的完整性:如果你从MacPorts安装PostgreSQL, pg_config将在/opt/local/lib/postgresql94/bin/pg_config。

当你安装MacPorts时,它已经将/opt/local/bin添加到你的PATH中。

所以,这将解决问题: $ sudo ln -s /opt/local/lib/postgresql94/bin/pg_config /opt/local/bin/pg_config . sh /opt/local/bin/pg_config . sh

现在pip install psycopg2将能够毫无问题地运行pg_config。

其他回答

对于那些运行OS X的人来说,这个解决方案对我来说是有效的:

1)安装postgresql .app:

http://www.postgresql.org/download/macosx/

2)然后打开终端并运行这个命令,将上面的{{version}}替换为Postgres的版本号:

导出路径= $路径:/应用程序/ Postgres.app /内容/版本/ {{version}} / bin

e.g.

导出路径= $路径:/应用程序/ Postgres.app /内容/版本/ 9.4 / bin

如果你使用的是mac,那么确保你已经在你的机器上安装了Postgresql。

快速了解pip的工作原理pip -> python2和pip3 -> python3,所以如果你想在python3上修复这个问题,你可以简单地sudo pip3 install psycopg2,这应该可以工作,可能。

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

如果你最近更新了python或更改了默认的python(比如从3.6到3.8)。下面的代码

sudo apt-get install python-dev   OR    sudo apt-get install python3-dev

将安装/工作于以前的python版本。

因此,如果您希望此命令适用于最近更新/更改的python版本,请尝试在以下命令中提到特定版本,如python3.8

sudo apt-get install python3.8-dev  

尝试以下内容

pip install wheel
export PATH=/path/to/compiled/postgresql/bin:"$PATH"
sudo apt-get install libpq-dev
sudo apt-get install python3.x-dev    **Change x with your version, eg python3.8**
pip install psycopg2-binary
pip install psycopg2