sql >> Base de Datos >  >> RDS >> PostgreSQL

PostgreSQL psycopg2 Python3.7.4 UnicodeDecodeError:el códec 'ascii' no puede decodificar el byte

Resolví el problema usando el paquete pyodbc.aquí:

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

tenga en cuenta que "CONTROLADOR={PostgreSQL Unicode};" es literalmente esa cadena. Para los otros argumentos, cámbielos en consecuencia. Aquí hay una función útil para pasar la cadena de conexión y la consulta desde la base de datos.

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