当我使用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配置引起? 提前谢谢
您应该设置连接编码,因为DB客户机在某些默认DB服务器编码中获得的结果无法在脚本中正确解释。您可以在获得与
db_connection_dw.setencoding("utf-8")
的连接后执行此操作。请参阅以下手册https://github.com/mkleehammer/pyodbc/wiki/Unicode相关问题 更多 >
编程相关推荐