问题:写好的python脚本,直接在命令行执行没问题,放在crontab内却在脚本中输出英文的地方报错
print('{} {} u5904u7406u81f3 {}'.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)
其中u5904u7406u81f3实际上是三个英文字符
鉴于crontab里没有tty/pts(终端)这个事实linux 执行python脚本,即不会执行$HOME/下的一些环境初始工作。之前就遇见过在crontab里执行个别linux命令有问题的情况linux 执行python脚本美国linux主机,此次恐怕也是这里引起的问题
在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命令前加上一行设置字符集的命令exportLANG=zh_CN.UTF-8,在观察输出鸟哥的linux私房菜,如下
SHELL=/bin/sh
USER=root
PATH=/usr/bin:/bin
PWD=/root
LANG=zh_CN.UTF-8
SHLVL=1
HOME=/root
LOGNAME=root
_=/usr/bin/env
可以看见其中多了一行字符集的设定,问题也就是在于此了。另外可以引申一下,其他类型的在crontab里执行命令遇见的环境变量相关的问题,大多也可以通过这些方法解决。