cx_Oracle读取Oracle数据库中文乱码问题解决

Posted 朝闻道,夕死可矣。

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了cx_Oracle读取Oracle数据库中文乱码问题解决相关的知识,希望对你有一定的参考价值。

在使用cx_Oracle模块读取Oracle数据库中的中文记录时,返回值皆为?,后google得此佳文,遂问题得以解决,特此记之。 



Oracle数据库版本是10g,字符集是AL32UTF8. 


编写的python脚本中需要加入如下几句:

import os 
os.environ[NLS_LANG] = SIMPLIFIED CHINESE_CHINA.UTF8 

这样可以保证select出来的中文显示没有问题。 

 

要能够正常的insert和update中文,还需要指定python源文件的字符集编码和Oracle一致。

# -*- coding: utf-8 -*- 

 



以上是关于cx_Oracle读取Oracle数据库中文乱码问题解决的主要内容,如果未能解决你的问题,请参考以下文章

在 Python 中使用 cx_Oracle 和 xlrd 列出列表的 executemany() 正在返回 TypeError

python+sqlalchemy 完成Oracle数据库读写操作

使用 cx_oracle 批量下载表

CX_Oracle - 将数据从 Oracle 导入 Pandas 数据框

Python安装cx_oracle操作

python 连接oracle(cx_Oracle模块)