在crontab中执行python脚本系统环境变量问题

问题

写好的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/sh
USER=root
PATH=/usr/bin:/bin
PWD=/root
SHLVL=1
HOME=/root
LOGNAME=root
_=/usr/bin/env

然后在crontab里的env命令前加上一行设置字符集的命令export LANG=zh_CN.UTF-8;,在观察输出,如下

SHELL=/bin/sh
USER=root
PATH=/usr/bin:/bin
PWD=/root
LANG=zh_CN.UTF-8    #已经能正确的输出$LANG
SHLVL=1
HOME=/root
LOGNAME=root
_=/usr/bin/env

可以看到其中多了一行字符集的设定,问题也就是在于此了。另外可以引申一下,其他类型的在crontab里执行命令遇到的环境变量相关的问题,大多也可以通过这种方式解决。

你可能感兴趣的:(Python,Linux相关)