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


当前回答

那些在macOS Catalina上使用zsh shell并安装了postgres应用程序的用户:

打开~/。ZSHRC文件,并添加以下行:

export PATH="/Applications/Postgres.app/Contents/Versions/latest/bin:$PATH"

然后关闭你所有的终端,重新打开,你的问题就解决了。

如果您不想关闭终端,只需输入source ~/。ZSHRC在任何你想继续工作的终端上。

其他回答

在Mac OS X和如果你使用Postgres应用程序(http://postgresapp.com/):

export PATH=$PATH:/Applications/Postgres.app/Contents/Versions/latest/bin

在此命令中不需要指定Postgres的版本。它总是指向最新的。

,做

pip install psycopg2

附注:如果“更改”没有反映,您可能需要重新启动终端/命令提示符

简单地运行以下命令:

sudo apt install libpq-dev

为我修正了这个问题

你可以使用pip或conda在任何平台上安装预编译的二进制文件:

python -m pip install psycopg2-binary

or

conda install psycopg2

请注意psycopg2-binary pypi页面建议在生产环境中从源代码构建:

二进制包是开发和测试的实际选择,但在生产中,建议使用从源代码构建的包

使用python -m pip install psycopg2可以使用从源代码构建的包。该过程将需要几个依赖项(文档)(强调我的):

一个C编译器。 Python头文件。它们通常安装在一个包中,例如python-dev。诸如error: Python.h: No such file或directory之类的消息表明Python头文件丢失。 libpq头文件。它们通常安装在libpq-dev之类的包中。如果您得到一个错误:libpq-fe.h:没有这样的文件或目录,那么您丢失了它们。 pg_config程序:通常由libpq-dev包安装,但有时不在PATH目录中。将它放在PATH中可以大大简化安装,所以尝试运行pg_config——version:如果它返回一个错误或一个意外的版本号,那么找到包含正确的libpq版本(通常是/usr/lib/postgresql/X.Y/bin/)的pg_config目录,并将其添加到PATH中: $ export PATH=/usr/lib/postgresql/X。Y / bin /: $路径 您只需要pg_config来编译psycopg2,而不是用于它的常规使用。

一旦一切就绪,就只需要运行标准了: $ PIP安装psycopg2 或者,从包含源代码的目录: $ python setup.py编译 $ python setup.py install

我很确定你也经历过和我一样的“问题”,因此我将为你提供一个极其简单的解决方案……

在你的例子中,你需要添加到$ 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

一个简单的解决方法是

pip install psycopg2==2.7.5