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


当前回答

如果你最近更新了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

其他回答

对于任何在Django应用程序中遇到这个问题并将其部署到AWS的人来说,本教程中描述的方法对我来说是有效的:https://realpython.com/deploying-a-django-app-and-postgresql-to-aws-elastic-beanstalk/

下面是作者对出现以下错误的解释:

Error: pg_config executable not found.

问题是我们试图安装psycopy2 (Postgres Python绑定),但我们还需要安装Postgres客户端驱动程序。因为默认情况下没有安装它们,所以我们需要先安装它们。 Eb将从名为“。”的文件夹中读取自定义的。config文件。Ebextensions”在项目的根级别。这些.config文件允许您安装包,运行任意命令和/或设置环境变量。文件中的。ebextensions”目录应该符合JSON或YAML语法,并按字母顺序执行。 首先要做的是安装一些包,以便pip install命令能够成功完成。为此,让我们创建一个名为.ebextensions/01_packages.config的文件:

packages:
  yum:
    git: []
    postgresql93-devel: []
    libjpeg-turbo-devel: []

EC2实例运行Redhat版本的Amazon Linux,因此我们可以使用yum来安装所需的包。现在,我们只安装三个包——git、Postgres客户端和Pillow的libjpeg。

我遇到这个问题是因为我没有安装postgres。如果你有brew安装运行

brew install postgresql

这应该可以解决问题。

阿里的解决方案为我工作,但我有麻烦找到bin文件夹的位置。在Mac OS X上找到路径的一个快速方法是打开psql(在顶部菜单栏中有一个快速链接)。这将打开一个单独的终端窗口,在第二行中,Postgres的安装路径将如下所示:

My-MacBook-Pro:~ Me$ /Applications/Postgres93.app/Contents/MacOS/bin/psql ; exit;

您的pg_config文件在bin文件夹中。因此,在安装psycopg2之前,设置pg_config文件的路径:

PATH=$PATH:/Applications/Postgres93.app/Contents/MacOS/bin/

或更新版本:

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

然后安装psycopg2。

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

# Install postgresql client libraries
sudo emerge postgresql-base

我发现这个页面提供了在我的mac上安装PostgreSQL的最佳说明,pip install命令在之后完美地工作:

https://www.codefellows.org/blog/three-battle-tested-ways-to-install-postgresql