Python2.7使用Oracle插入中文字符报错问题解决方案

本文介绍了在使用Python查询操作系统进程信息并写入Oracle数据库时遇到的UnicodeEncodeError错误。通过设置环境变量NLS_LANG和调整Python默认编码为UTF-8的方法成功解决了由中文字符引发的问题。

今天上午运行python程序查询操作系统进程信息并写入oracle数据库时遇到如下错误:

UnicodeEncodeError: ‘ascii’ codec can’t encode characters in position 1-7: ordinal not in range(128)

经排查发现是由于中文字符导致的。
百度查到很多解决方案,尝试多次之后,只有下面的办法有效果:

解决办法:
os.environ['NLS_LANG']='SIMPLIFIED CHINESE_CHINA.UTF8'

将脚本部署到crontab中之后,运行过程中还是报上面的错误,加入下面的命令,解决!

import sys
reload(sys)
sys.setdefaultencoding('utf-8')
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值