我的代码
主要最近搞个小脚本隔一段时间请求一次看看录取通知书发了没有.结果正常运行python3 luqu.py 完全可以正常运行.但是一旦用的corntab当中就无法执行.
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import requests
import json
payload = dict(inputinfo='身份证号码')
mheaders = {
'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Mobile Safari/537.36',
'X-Requested-With': 'XMLHttpRequest'}
def errormessage():
body = "https://sc.ftqq.com/SCU17301T0b5df5bc1a5347f47bea712f96c43a395a23d1832df92.send?text=垃圾学校服务器挂了啦&desp=垃圾学校服务器挂了啦"+".."
requests.get(body)
def successmessage(body):
requests.get(body)
# try:
r = requests.post(
'http://zs.weixin.zjhzcc.edu.cn/index.php/Wap/SearchInfo/post_admission.html', data=payload, headers=mheaders)
if r.status_code == 200:
myjson = json.loads(r.content.decode("utf-8"))
if(myjson['state'] == 'success'):
print(myjson['info']['tzsh'])
if myjson['info']['tzsh'] == '待更新':
print("express wait for update")
else:
body = "https://sc.ftqq.com/SCU17301T0b5df5bc1a5347f47bea712f96c43a395a23d1832df92.send?text=录取通知书快递更新啦&desp=EMS快递单号为:" + \
str(myjson['info']['tzsh'])+".."
successmessage(body)
else:
errormessage()
else:
errormessage()
# except BaseException:
# errormessage()
然后通过谷歌查询.查询到如何查看log.看下面的corn代码
29 * * * * /usr/bin/python3 /home/hdy/luqu/luqu.py >> /home/hdy/luqu/luqu.log 2>&1
通过这种方式就可以把log打印到指定的目录.
打印出这个问题UnicodeEncodeError: ‘ascii’ codec can’t encode characters in ordinal not in range(128)
这个问题之前也出现过..原因是系统的语言不一样.在centos当中只需要输入
export LANG="en_US.UTF-8"
就可以正常的打印出中文代码了.
但是由于在corntab当中环境变量和系统的不太一样.所以需要注意下面的几点.
注意事项
绝对路径的python路径
- which python3 就可以得到执行的python路径
小心环境问题
我这里解决的方法是通过手动设置语言.
最终解决方法
36 * * * * export LANG="en_US.UTF-8";/usr/bin/python3 /home/hdy/luqu/luqu.py >> /home/hdy/luqu/luqu.log 2>&1
只是在代码之前之前加上了;export LANG="en_US.UTF-8";
然后一切就执行成功了.
作者:恶搞大王