2

嘿,我在尝试使用来自 ubuntu 的 python 脚本运行 cron 作业时遇到了问题。这就是我所做的:

1.) 编写了一个简单的 tkinter 应用程序:代码源来自这个 url - http://www.ittc.ku.edu/~niehaus/classes/448-s04/448-standard/simple_gui_examples/sample.py

#!/usr/bin/python
from Tkinter import *
class App:
    def __init__(self,parent):
        f = Frame(parent)
        f.pack(padx=15,pady=15)
        self.entry = Entry(f,text="enter your choice")
        self.entry.pack(side= TOP,padx=10,pady=12)
        self.button = Button(f, text="print",command=self.print_this)
        self.button.pack(side=BOTTOM,padx=10,pady=10)
        self.exit = Button(f, text="exit", command=f.quit)
        self.exit.pack(side=BOTTOM,padx=10,pady=10)

    def print_this(self):
        print "this is to be printed"

root  = Tk()
root.title('Tkwidgets application')
app = App(root)
root.mainloop()

2.) 将脚本更改为可执行文件:

chmod 777 sample.py

3.) 将脚本添加到我的 cronjob 中,以便每分钟运行一次以进行测试。我打开 crontab -e 并将以下内容添加到我的文件中:

 * * * * * /home/bbc/workspace/python/tkinter/sample.py 

4.) 免责声明:我没有为 tkinter 添加任何额外的环境变量,也没有在 /etc/init.d/cron 更改我的 cronjob 脚本

5.) 我通过 tail -f /var/log/syslog 跟踪 cron 作业

$ tail -f /var/log/syslog
Jul  7 18:33:01 bbc CRON[11346]: (bbc) CMD (/home/bbc/workspace/python/tkinter/sample.py)
Jul  7 18:33:01 bbc CRON[11343]: (CRON) error (grandchild #11344 failed with exit status 1)
Jul  7 18:33:01 bbc CRON[11343]: (CRON) info (No MTA installed, discarding output)
Jul  7 18:33:01 bbc CRON[11342]: (CRON) error (grandchild #11346 failed with exit status 1)
Jul  7 18:33:01 bbc CRON[11342]: (CRON) info (No MTA installed, discarding output)

任何有关调试此问题的帮助将不胜感激...

4

3 回答 3

3

我不确定你期望在这里发生什么。cronjob 将无法访问可以显示 GUI 的显示器,因此该按钮将永远不会显示,因此print_this永远不会运行

FWIW,当我尝试运行您的代码时出现错误:

  File "./t.py", line 4
    def __init__(self,parent):
      ^
IndentationError: expected an indented block

不确定这是否只是由复制/粘贴到页面中引起的,或者它是否是您的代码的真正问题。

于 2013-07-08T01:44:53.190 回答
2

在 linux mint 17 中,我必须执行以下操作:

使脚本可执行
~$chmod +x script.py

您必须为 localhost 启用 X ACL 才能连接到 GUI 应用程序才能工作
~$ xhost +local:

在 crontab 中添加以下行 "env DISPLAY=:0.0"
* * * * * env DISPLAY=:0.0 /usr/bin/python /your-script-somewhere.py

还有一行到 crontab ">/dev/null 2>&1"
* * * * * env DISPLAY=:0.0 /usr/bin/python /your-script-somewhere.py >/dev/null 2>&1

您可以检查 /var/log/syslog 文件中的错误
~$ tail -20 /var/log/syslog

更多信息:
https ://help.ubuntu.com/community/CronHowto

于 2014-11-14T01:04:52.670 回答
1

我使用 crontab 运行 bash 文件

30 12 * * 1,2,3,4,5 /home/edward/SSF/SW/EODWD.sh

在终端中——使用 crontab -e

bash 文件执行任意数量的其他程序

/home/edward/SSF/SW/EODWD.py >> /home/edward/Desktop/eodmail.log 等待

此示例还自动将 EODWD.py 中的所有打印语句发送到日志文件

等待语句在执行下一个命令之前强制竞争

这只有在两个文件( *.py 和 *.sh )都被设为可执行的情况下才有效

于 2013-07-21T18:22:35.867 回答