Ho risolto il problema utilizzando il pacchetto pyodbc.here:
import pyodbc
import pandas as pd
conn_str = (
"DRIVER={PostgreSQL Unicode};"
"DATABASE=adp_report;"
"UID=db_name;"
"PWD=password;"
"SERVER=111.111.11.11;"
"PORT=5432;"
)
nota che "DRIVER={PostgreSQL Unicode};" è letteralmente quella stringa. Per gli altri argomenti cambiali di conseguenza. Ecco una pratica funzione per passare la stringa di connessione e la query dal database.
def query_db(query):
conn = pyodbc.connect(conn_str)
dat = pd.read_sql(query, conn)
conn.close()
return dat