我正在使用 virtualenv
,我需要安装"psycopg2" .
我做了以下事情:
pip install http://pypi.python.org/packages/source/p/psycopg2/psycopg2-2.4.tar.gz#md5=24f4368e2cfdc1a2b03282ddda814160
我有以下消息:
Downloading/unpacking http://pypi.python.org/packages/source/p/psycopg2/psycopg2
-2.4.tar.gz#md5=24f4368e2cfdc1a2b03282ddda814160
Downloading psycopg2-2.4.tar.gz (607Kb): 607Kb downloaded
Running setup.py egg_info for package from http://pypi.python.org/packages/sou
rce/p/psycopg2/psycopg2-2.4.tar.gz#md5=24f4368e2cfdc1a2b03282ddda814160
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'.
Complete output from command python setup.py egg_info:
running egg_info
creating pip-egg-info\psycopg2.egg-info
writing pip-egg-info\psycopg2.egg-info\PKG-INFO
writing top-level names to pip-egg-info\psycopg2.egg-info\top_level.txt
writing dependency_links to pip-egg-info\psycopg2.egg-info\dependency_links.txt
writing manifest file 'pip-egg-info\psycopg2.egg-info\SOURCES.txt'
warning: manifest_maker: standard file '-c' not found
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
Storing complete log in C:\Documents and Settings\anlopes\Application Data\pip\p
ip.log
我的问题,我只需要这样做以使psycopg2工作?
python setup.py build_ext --pg-config /path/to/pg_config build ...
26 回答
除了安装所需的包之外,我还需要手动将PostgreSQL bin目录添加到PATH .
$vi ~/.bash_profile
在
export PATH
之前添加PATH=/usr/pgsql-9.2/bin:$PATH
.$source ~/.bash_profile
$pip install psycopg2
在Windows XP上,如果未安装postgres,则会出现此错误...
我在PG的下载网站上使用RedHat / CentOS存储库安装了Postgresql92 http://www.postgresql.org/download/linux/redhat/
要获得pg_config,我必须将/usr/pgsql-9.2/bin添加到PATH .
我之前已经完成了这个操作,然后在Windows中首先安装到基础python安装中 .
然后,您手动将已安装的psycopg2复制到virtualenv安装 .
它不漂亮,但它的工作原理 .
我发现这篇文章正在寻找解决这个问题的Linux解决方案 .
这个post by "goshawk"给了我解决方案:如果你在Ubuntu / Debian上运行
sudo apt-get install libpq-dev python-dev
.更新
由于越来越多的人发现这个答案很有用并且发布了他们自己的解决方案,这里有一个列表:
Debian / Ubuntu
Python 2
Python 3
其他
如果以上都不能解决您的问题,请尝试
要么
在CentOS上,你需要postgres开发包:
这至少是CentOS 6的解决方案 .
在Mac Mavericks上使用Postgres.app版本9.3.2.0 RC2我需要在安装Postgres后使用以下代码:
sudo PATH=$PATH:/Applications/Postgres.app/Contents/Versions/9.3/bin pip install psycopg2
如果你在Mac上,你可以使用自制软件
所有其他选项都在这里:http://www.postgresql.org/download/macosx/
祝好运
我最近在Windows机器上配置了psycopg2 . 最简单的安装是使用Windows可执行二进制文件 . 你可以在http://stickpeople.com/projects/python/win-psycopg/找到它 .
要在虚拟环境中安装本机二进制文件,请使用easy_install:
对于Python 3,你应该在Debian下使用
sudo apt-get install libpq-dev python3-dev
.这对我有用(On RHEL,CentOS:
现在包含你的postgresql二进制目录的路径和你的pip install:
确保包含正确的路径 . 就这样 :)
更新:对于python 3,请安装
python3-devel
而不是python-devel
如果您使用的是Mac OS,则应从源代码安装PostgreSQL . 安装完成后,您需要使用以下命令添加此路径:
或者你可以像这样追加路径:
在
.profile
文件或.zshrc
文件中 .这可能因操作系统而异 .
您可以按照http://www.thegeekstuff.com/2009/04/linux-postgresql-install-and-configure-from-source/的安装过程进行操作
到目前为止,答案太像魔术食谱了 . 您收到的错误告诉您pip无法找到PostgreSQL查询库的必需部分 . 可能这是因为您将它安装在操作系统的非标准位置,这就是消息建议使用--pg-config选项的原因 .
但更常见的原因是您根本没有安装libpq . 这通常发生在没有安装PostgreSQL服务器的机器上,因为您只想运行客户端应用程序,而不是服务器本身 . 每个OS /发行版都不同,例如在Debian / Ubuntu上你需要安装libpq-dev . 这允许您针对PostgreSQL查询库编译和链接代码 .
大多数答案还建议安装Python开发库 . 小心 . 如果您只使用发行版安装的默认Python,那将会有效,但如果您有更新的版本,则可能会导致问题 . 如果你已经在这台机器上构建了Python,那么你已经拥有了编译C / C库以与Python接口所需的开发库 . 只要您使用正确的pip版本,安装在与python二进制文件相同的bin文件夹中的那个版本,那么您就已经完成了设置 . 无需安装旧版本 .
在
Debian/Ubuntu
:首先安装并构建
psycopg2
包的依赖项:然后在您的虚拟环境中编译并安装
psycopg2
模块:我已经和它斗争了好几天,并且最终想出了如何让“pip install psycopg2”命令在Windows(运行Cygwin)中的virtualenv中运行 .
我正在点击“未找到pg_config可执行文件” . 错误,但我已经在Windows中下载并安装了postgres . 它也安装在Cygwin中;在Cygwin中运行“which pg_config”给出了“/ usr / bin / pg_config”,并且运行“pg_config”给出了合理的输出 - 但是与Cygwin一起安装的版本是:
VERSION = PostgreSQL 8.2.11
这不适用于当前版本的psycopg2,它似乎至少需要9.1 . 当我将“c:\ Program Files \ PostgreSQL \ 9.2 \ bin”添加到我的Windows路径时,Cygwin pip安装程序能够找到正确版本的PostgreSQL,并且我能够使用pip成功安装模块 . (无论如何,这可能比使用Cygwin版本的PostgreSQL更好,因为本机版本会跑得快得多) .
在Fedora 24上:对于Python 3.x.
激活您的虚拟环境:
对于低级Windows用户来说,不得不从下面的链接安装psycopg2,只需将其安装到您设置的任何Python安装中 . 它会将名为“psycopg2”的文件夹放在python安装的site-packages文件夹中 .
之后,只需将该文件夹复制到virtualenv的site-packages目录中,就可以了 .
这里是你可以找到安装psycopg2的可执行文件的链接
http://www.lfd.uci.edu/~gohlke/pythonlibs/
在OpenSUSE 13.2上,这修复了它:
我可以通过以下命令将它安装在Windows机器中并使用带有python 2.7的Anaconda / Spyder:
然后 Build 与数据库的连接:
在 Arch 基础分布中:
Psycopg2取决于Postgres库 . 在Ubuntu上您可以使用:
然后:
在Ubuntu上我只需要postgres开发包:
*在virtualenv中测试过
在OSX 10.11.6(El Capitan)
在OSX上使用macports:
如果pip不起作用,你可以从这里下载.whl文件https://pypi.python.org/pypi/psycopg2解压缩..比
python setup.py install
在
Gentoo
中尝试这个: