utf8使用python pyodbc连接到Docker容器中的Sybase数据库时出现的编码问题

2024-10-01 09:18:32 发布

您现在位置:Python中文网/ 问答频道 /正文

当我使用pyodbc创建连接时

connectionString = ('DRIVER='+driver+';SERVER='+server+';PORT='+port+';UID='+username+';PWD='+password+';DATABASE='+db_environment)
db_connection_dw = pyodbc.connect(connectionString)
cursor = db_connection_dw.cursor()
cursor.execute(sql_query_string)
print(cursor.fetchone())

对于包含特殊字符的CharField类型的字段,我得到了奇怪的结果。 例如,我得到的是'M\x8adic'而不是'Mèdic'

Dockerfile

FROM python:3
ENV PYTHONUNBUFFERED 1
ENV PYTHONDONTWRITEBYTECODE 1
ENV PYTHONIOENCODING=utf-8

ADD devartodbcase_amd64.deb /tmp/devartodbcase_amd64.deb
RUN apt-get clean && \
    apt-get update && \
    apt-get install -y locales locales-all && \
    locale-gen ca_ES.UTF-8 && \
    apt-get install -y gettext libgettextpo-dev g++ unixodbc unixodbc-dev libaio1 && \
    cd /tmp/ && dpkg -i devartodbcase_amd64.deb

ENV LANG ca_ES.UTF-8
ENV LC_ALL ca_ES.UTF-8

COPY ./requirements.txt /requirements.txt
RUN pip install --upgrade pip==20.0.2 && pip install -r /requirements.txt

RUN mkdir /app
WORKDIR /app
COPY ./app/ /app

requirements.txt

Django==2.2.7
djangorestframework==3.10.3
django-filter==2.2.0
psycopg2==2.8.4
pyodbc==4.0.28

numpy==1.18.1
pandas==1.0.1

python-decouple==3.3
dj-database-url==0.5.0

django-widget-tweaks==1.4.5

SQLAlchemy==1.3.13

问题是否由驱动程序配置、Dockerfile配置引起? 提前谢谢


Tags: installrunenvtxtappdbgetapt
1条回答
网友
1楼 · 发布于 2024-10-01 09:18:32

您应该设置连接编码,因为DB客户机在某些默认DB服务器编码中获得的结果无法在脚本中正确解释。您可以在获得与db_connection_dw.setencoding("utf-8")的连接后执行此操作。请参阅以下手册https://github.com/mkleehammer/pyodbc/wiki/Unicode

相关问题 更多 >