PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

PostgreSQL psycopg2 Python3.7.4 UnicodeDecodeError :le codec 'ascii' ne peut pas décoder l'octet

J'ai résolu le problème en utilisant le package pyodbc.ici :

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;"
    )

notez que le "DRIVER={PostgreSQL Unicode} ;" est littéralement cette chaîne. Pour les autres arguments, changez-les en conséquence. Voici une fonction pratique pour transmettre la chaîne de connexion et la requête de la base de données.

def query_db(query):
    conn = pyodbc.connect(conn_str)
    dat = pd.read_sql(query, conn)
    conn.close()
    return dat