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

被折叠的 条评论
为什么被折叠?



