python在通过crontab运行时不提取zipfile

时间:2017-12-18 12:15:29

标签: python cron ubuntu-16.04

#!/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)

系统配置

  1. Ubuntu OS 16.04
  2. Python 2.7.12
  3. $ 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
    

    注意:

    1. 我检查了syslog,它说cron正在成功运行
    2. 上面的代码没有错误
    3. 也使python程序可以通过chmod + x filename.py
    4. 执行

      请帮助我在哪里出错。

2 个答案:

答案 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:记录脚本中的每一行