81

Is it possible to install psycopg2 into a virtualenv when PostgreSQL isn't installed on my development system—MacBook Pro with OS X 10.6?

When I run pip install psycopg2 from within my virtualenv, I received the error shown below.

I'm trying to connect to a legacy database on a server using Django, and I'd prefer not to install PostgreSQL on my development system if possible.

Why not install PostgreSQL?

I received an error when installing PostgreSQL using homebrew. I have Xcode4—and only Xcode4—installed on my MacBook Pro and am thinking it's related to missing gcc 4.0. However, this is a problem for another StackOverflow question.

Update 8:37 AM on April 12, 2011: I'd still like to know if this is possible without installing PostgreSQL on my MacBook Pro. However, I ran brew update and forced a reinstallation of ossp-uuid with brew install --force ossp-uuid and now brew install postgresql works. With PostgreSQL successfully installed, I was able to pip install psycopg2 from within my virtualenv.

Error from pip install psycopg2

$ pip install psycopg2
Downloading/unpacking psycopg2
  Running setup.py egg_info for package 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'.
    Complete output from command python setup.py egg_info:
    running 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
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 /Users/matthew/.pip/pip.log

Preliminary Research

Below are the articles I read as preliminary research:

6
  • 1
    see the correct answer here: stackoverflow.com/questions/5420789/… Commented Jan 17, 2012 at 4:46
  • that question's answer is for debian/ubuntu, so does not help if you are using osx. Commented Feb 11, 2012 at 11:21
  • On Centos 6 and Postgres 9.1 set the correct path to pg_config in your virtualenv: export PATH=/usr/pgsql-9.1/bin:"$PATH" Commented Jun 15, 2012 at 8:43
  • 2
    Installing PostgreSQL should not be a requirement to develop django. We need to do this because our requirements.txt for the server lists psycopg without us ever using it locally. It's all a bit too tightly coupled and causes a lot of configuration grief. Commented May 27, 2014 at 16:01
  • 1
    Wow, not one answer to this posting concerning the specifics of a virtualenv on Mac setup. Correct me if I'm wrong. Commented Sep 17, 2014 at 23:23

15 Answers 15

80
apt-get install libpq-dev

helped me on debian squeeze

From comments:

apt-get install python-dev-is-python3
Sign up to request clarification or add additional context in comments.

3 Comments

And maybe apt-get install python-dev too.
apt-get install python-dev-is-python3 nowadays 10 years after (2023)
this worked for me on ubuntu 24.02
52

psycopg depends on pg_config command, and if you don't have it, you can't install psycopg.

If system installation is a problem to you, why don't you try compiling PostgreSQL and including generated bin files in your $PATH? Like:

export PATH=/path/to/compiled/postgresql/bin:"$PATH"
pip install psycopg2

5 Comments

"pip install psycopg" does not work any more (error 404), use "pip install psycopg2" instead.
If you are on the Mac. Then, use the command "locate pg_config" to find the path. In my OSX Mavericks with the Postgresql installed by Port the path is /opt/local/lib/postgresql92/bin
Works on Windows too! +1
locate postgres can help find the path to your compiled postgreSQL bin
I do not have pg_config and have been running with psycopg2 forever. This is out of date.
34
brew install postgresql

export LDFLAGS="-L/usr/local/opt/openssl/lib"

export CPPFLAGS="-I/usr/local/opt/openssl/include"

pip3 install psycopg2

4 Comments

For some reason this worked for me on Mac OS X when several other solutions didn't. I already had postgresql installed and pg_config on my PATH, but still got the same error when installing psycopg2. The two export lines solved it for me.
After several hours of struggling with this error this solution solved my probelm. thank you.
Can somebody explain why this works? What has openssl got to do here ?
@AnantaKRoy openssl is required by psycopg for secure ssl connections to postgres. The flags are the key here. Apple has moved around openssl and the setups are looking for them somewhere else.
11
apt-get install libpq-dev

helped me in debian squeeze too . After that do pip install psycopg2. I faced problem of pg_config not found problem when i was setting up my environment on heroku , now its working fine .

Comments

6

You need to install the python-dev package in order to make use of python extensions such as psycopg2. I don't know how to install packages in mac but I run the following commands to install a python package on my Ubuntu machine.

sudo apt-get install python-dev 

Or

sudo apt-get install python3-dev

if you are using Python3.x.

Once the installation is finished run the following command within your virtual environment.

pip install psycopg2

Comments

4

You don't need the complete PostgreSQL installed: you only need the client side libraries.

2 Comments

Do you have a recommendation on installing the PostgreSQL client-side libraries on OS X?
I have no recommendation, I am not an OS X user. The fink build uses postgresql90-dev to build (probably for the .h) and postgresql90-shlibs (probably for the libpq), but I don't know how to rank this option w.r.t. other packages (which I don't know about) or building the libpq from source. Ref. fink.cvs.sourceforge.net/fink/dists/10.4/unstable/main/finkinfo/…
3

I solved it in MAC OSX using :

$ wget https://ftp.postgresql.org/pub/source/v9.5.3/postgresql-9.5.3.tar.bz2
$ tar xfv postgresql-9.5.3.tar.bz2
$ cd postgresql-9.5.3
$ ./configure
$ make
$ cd src/bin/pg_config
$ export PATH=`pwd`:"$PATH"
$ pip install psycopg2

3 Comments

This seems to answer the initial question properly.
Will pip compile libpq statically into psycopg2, in other words, can the postgresql installation be removed afterwards?
as alternative, just do pip install psycopg2-binary
3

Use pip install psycopg2-binary, it worked for me when pip install psycopg2 wasn't working.

1 Comment

This solution works for me
1

Using the method you described in your April 12th update, I was able to install PostgreSQL(+1). Note that I originally was running Python 2.7.1 (32bit) and homebrew threw several errors and warnings regarding using a 32bit version of Python. I have since switched the 64/32 bit version of 2.7.1 and it works like a champ.

Regarding the pyscopg2, I was able to install it into my virtual environment from source by editing setup.cfg. I set pg_config to correct path inside homebrew's Cellar (pg_config=/usr/local/Cellar/postgresql/9.0.4/bin/pg_config). After saving the changes, I ran python setup.py install with zero issues. It's worth noting that I did not set the Mac's default python setting to 32 bit. I used the new 64 bit from start to finish.

After looking over some of the documentation, I think if I added homebrew's postgresql path to the system path I could have used pip to install it.

Reference:
http://favosdream.blogspot.com/2009/09/make-psycopg2-and-readline-work-in-snow.html

Update 6-8-2011:
While porting a project written on OS X to Windows 7, I found out that I had to install PostgreSQL on Windows as well. This ended up creating another user on my start up screen and other things that I just didn't like. While doing some digging I found Windows drivers for PostgreSQL here. I have since uninstalled the full PostgreSQL and installed the ODBC drivers which, thus far, work great.

To address the original question, after doing a bit more digging I think I found the equivalent ODBC for OS X here. I have not had a chance to try them out, but the concept works very well on Windows 7. I will update this when I get a chance to try them out. Until then, I hope this helps.

2 Comments

On Windows, you do not need to install Postgresql, but merely have the binaries in your path. This can be accomplished by downloading a zip file of the binaries enterprisedb.com/products-services-training/pgbindownload and adding that directory to your path (i.e. changing the PATH environment variable). Copy them somewhere safe/known before adding the path to make life easier!
@wcdolphin Thanks for the input. That sure would have made life easier.
1

All from the above doesn't work for me (OS Catalina 10.15.1)

There was a conflict with classical postgres and homebrew version. Please delete homebrew version by command

$ brew uninstall postgresql

and then install it from the official website:

$ sudo mkdir -p /etc/paths.d && echo /Applications/Postgres.app/Contents/Versions/latest/bin | sudo tee /etc/paths.d/postgresapp

It is actual for a simple psycopg2 install or django-heroku package.

Comments

1

if you have recently updated python or changed default python (let's say from 3.6 to 3.8). The following code

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

will be installing/working for the previous python version.

so if you want this command to work for the recently updated/changed python version try mentioning that specific version like python3.8 in command like

sudo apt-get install python3.8-dev  

try above with following

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

Comments

0

As I never needed to install postgresql database on this server I installed the following libraries on Ubuntu 14_04 version before running pip install psycopg2 on the same server

apt-get install libpq-dev python-dev and then executed pip install psycopg2 within virtual env.

Output Collecting psycopg2 Using cached psycopg2-2.6.1.tar.gz Building wheels for collected packages: psycopg2 Running setup.py bdist_wheel for psycopg2 Stored in directory: /root/.cache/pip/wheels/e2/9a/5e/7b620848bbc7cfb9084aafea077be11618c2b5067bd532f329 Successfully built psycopg2 Installing collected packages: psycopg2 Successfully installed psycopg2-2.6.1

Comments

0

I know you are asking for development environment but if you are deploying on server say, Heroku. Just add below line in the requirements.txt of your project.

django-heroku==0.3.1

As this package itself will install the required packages like psycopg2 on server deployment.

Comments

0

Try to specify the version and it'll works, do it inside the venv

pip install psycopg2-binary==2.8.6

Comments

0

based on my experience, apt install libpq-dev then try to install psycopg2 inside venv will fix many issues, however for more information you can refer to this link: https://www.psycopg.org/docs/install.html

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.