标签:www. 配置信息 div 搜索 proc gbk iat 开启 disable
系统环境变量
变量名称: NLS_LANG
变量值:SIMPLIFIED CHINESE_CHINA.ZHS16GBK
在用cx_oracle连接oracle数据库进行导入的时候出现了很奇怪的问题:
oracle服务器NLS_CHARACTERSET为AL32UTF8,要进行导入的文件编码也是utf8,而用cursor.executemany进行导入的时候出现了错误:‘gbk‘ codec can‘t encode character u‘\ue85f‘ in position 1: illegal multibyte sequence。
有点莫名其妙,从utf8到utf8也会经过字符编码转换?
用bing搜索了一下,发现有人遇到同样的问题:http://www.thecodingforums.com/threads/cx_oracle-and-utf8.354728/。发现是环境变量nls_lang的问题,于是将nls_lang设置为’AMERICAN_AMERICA.AL32UTF8‘,
应该‘SIMPLIFIED CHINESE_CHINA.AL32UTF8’也行,不过没试过。设置之后导入就没问题了。设置方法可以直接改环境变量,也可以通过python来改:os.environ[‘nls_lang‘] = ‘AMERICAN_AMERICA.AL32UTF8‘ 。
标签:www. 配置信息 div 搜索 proc gbk iat 开启 disable
原文地址:http://www.cnblogs.com/My-Memory/p/7919621.html