7

I'm trying to connect to a postgres database with psycopg2:

import psycopg2

try:
    conn = psycopg2.connect("dbname='puppetdb' user='puppetdb' host='172.17.0.1' port='5432' password='puppetdb'")
except Exception, e:
    print "I am unable to connect to the database"
    print e

Which returns:

I am unable to connect to the database
'module' object has no attribute 'connect'

I've made sure that psycopg2 is installed with pip install psycopg2 and it seems like this should work according to the documentation.

Am I doing this wrong?

Philip Kirkbride
  • 21,381
  • 38
  • 125
  • 225

3 Answers3

12

This could be a name shadowing issue.

If your file is called psycopg2.py or if you have a psycopg2.py/psycopg2.pyc file in that directory then it will import your script over the actual pyscopg2 module.

If that's the issue then rename your file to something else.

HackerShark
  • 211
  • 2
  • 7
  • Note that in my case I had a json.py file locally, which psycopg2 seems to reference internally, so it was leading to this too. – Eduardo Oct 30 '18 at 17:31
12

For me it was because I was uploading a zip to AWS lambda and wasn't zipping the folder recursively, i.e. zip lambda.zip * instead of zip -r lambda.zip *. So the module folder was empty.

maxymoo
  • 35,286
  • 11
  • 92
  • 119
-1
import psycopg2               # Acc�s PostgreSQL
import psycopg2.extras        # Goodies PostgreSQL

try:
     conn = psycopg2.connect("dbname='puppetdb' user='puppetdb' 
host='172.17.0.1' port='5432' password='puppetdb'")

except psycopg2.Error as e:
    print("I am unable to connect to the database")
    print(e)
Maryam Homayouni
  • 905
  • 9
  • 16
delos
  • 1