在crontab中执行python脚本系统环境变量问题
来源:互联网 发布:黄惠康 知乎 编辑:程序博客网 时间:2024/06/17 16:46
问题
写好的python脚本,直接在命令行执行没问题,放到crontab之后却在脚本中输出中文的地方报错:
print('{} {} \u5904\u7406\u81f3 {}'.format(time.strftime('%H:%M:%S', time.localtime()), log, line_result[3]))UnicodeEncodeError: 'ascii' codec can't encode characters in position 27-29: ordinal not in range(128)
其中\u5904\u7406\u81f3
实际上是三个中文字符
解决
在crontab里的env命令之前前加上一行设置字符集的命令export LANG=zh_CN.UTF-8;
原理
鉴于crontab里没有tty/pts(终端)这个事实,即不会执行$HOME/
下的一些环境初始工作。之前就遇到过在crontab里执行某些linux命令有问题的情况(参见),看这个报错很明显能联想到系统变量$LANG,估计也是这个特性导致的问题
在linux命令行下执行env
命令,输出当前tty/pts的系统变量值(挺多),其中有LANG=en_US.UTF-8
或者LANG=zh_CN.UTF-8
,但是env命令放到crontab里却只输出很少的几行内容
SHELL=/bin/shUSER=rootPATH=/usr/bin:/binPWD=/rootSHLVL=1HOME=/rootLOGNAME=root_=/usr/bin/env
然后在crontab里的env命令前加上一行设置字符集的命令export LANG=zh_CN.UTF-8;
,在观察输出,如下
SHELL=/bin/shUSER=rootPATH=/usr/bin:/binPWD=/rootLANG=zh_CN.UTF-8 #已经能正确的输出$LANGSHLVL=1HOME=/rootLOGNAME=root_=/usr/bin/env
可以看到其中多了一行字符集的设定,问题也就是在于此了。另外可以引申一下,其他类型的在crontab里执行命令遇到的环境变量相关的问题,大多也可以通过这种方式解决。
0 0
- 在crontab中执行python脚本系统环境变量问题
- crontab中使用环境变量的方法(手动执行shell脚本可以,在定时任务中不行)
- Linux下,将python安装在个人目录下,配置环境变量,以及解决crontab执行python脚本会出错的问题
- 在Crontab中执行PHP脚本
- Python脚本在crontab定时任务中无法运行,但是对应脚本手动执行成功
- 由crontab执行expect脚本问题引发的--crontab环境变量问题
- crontab 定时执行python脚本
- crontab 定时执行python脚本
- crontab 中 python 脚本执行失败的解决方法
- crontab 中 python 脚本执行失败的解决方法
- crontab启动shell脚本的环境变量问题
- crontab启动shell脚本的环境变量问题
- crontab 下python脚本不执行bug
- 同步时钟脚本在crontab中遇到的问题
- 如何在IIS中执行Python脚本
- 在linux系统中,执行php脚本
- 在linux系统中,执行php脚本
- shell在crontab中不能执行问题的解决方案
- oracle常用语句
- Java多线程-Thread与Runnable说明
- 使用iText生成doc
- java解析XML文件---SAXReader
- Sublime Text 无法使用Package Control或插件安装失败的解决方法
- 在crontab中执行python脚本系统环境变量问题
- MySql结构语言 ————函数
- Collection 与Collections
- 轻松找回丢失的R文件!
- android双imei的获取
- ajax多个data传值
- 博客
- 携程移动端架构演进与优化之路
- Java基础-IO流4 装饰设计模式