#!/usr/bin/python
import requests, zipfile, StringIO, sys
extractDir = "myfolder"
zip_file_url = "download url"
response = requests.get(zip_file_url)
zipDocument = zipfile.ZipFile(StringIO.StringIO(response.content))
zipinfos = zipDocument.infolist()
for zipinfo in zipinfos:
extrat = zipDocument.extract(zipinfo,path=extractDir)
系统配置
$ python extract.py
当我使用上面的命令在终端上运行代码时,它可以正常工作并创建文件夹并将文件解压缩到其中。
同样,当我使用sodu权限创建一个cron作业时,代码会执行,但不会创建任何文件夹或提取文件。
crontab命令: -
40 10 * * * /usr/bin/sudo /usr/bin/python /home/ubuntu/demo/directory.py > /home/ubuntu/demo/logmyshit.log 2>&1
也尝试了
40 10 * * * /usr/bin/python /home/ubuntu/demo/directory.py > /home/ubuntu/demo/logmyshit.log 2>&1
注意:
请帮助我在哪里出错。
答案 0 :(得分:1)
Oups,在crontab中运行Python脚本没有什么问题,但是由于环境不是您习惯的环境,因此可能会发生许多不好的事情。
当您键入交互式shell python directory.py
时,PATH和所有必需的PYTHON环境变量已设置为登录和交互式shell初始化的一部分,默认情况下当前目录是您的主目录或您当前的任何位置是
当从crontab运行相同的命令时,未指定当前目录(但可能不是您所期望的),PATH仅为/bin:/usr/bin
并且未设置python环境变量。这意味着您必须在crontab文件中调整环境变量,直到获得正确的Python环境,并设置当前目录。
答案 1 :(得分:0)
我有一个非常类似的问题,结果发现cron不喜欢导入matplotlib,我最终不得不指定Agg后端。我通过在每一行之后放置日志语句来计算它,看看程序在它被淘汰之前得到了多远。当然,我的日志是空的,这让我觉得它在进口时崩溃了。
TLDR:记录脚本中的每一行