PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

PostgreSQL psycopg2 Python3.7.4 UnicodeDecodeError:il codec 'ascii' non può decodificare byte

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