我編寫了一個 python 腳本來運行某些 cron 作業并使用 crontab 來執行相同的操作。以下是代碼片段:import osimport inspectfrom crontab import CronTabdef add_cron_job(scripts_list,frequency): my_cron = CronTab(user='simrat') for script in scripts_list: if not cron_exists(my_cron,script): command = 'python {}'.format(script) job = my_cron.new(command=command, comment=script) job.minute.every(frequency) my_cron.write()def cron_exists(my_cron, script): for job in my_cron: if job.comment == script: return True return Falseif __name__ == "__main__": #Frequency of every 1 minute test_script = ['test1.py', 'test2.py'] add_cron_job(test_script,1) #Frequency of every 1 day test_script2 = ['test3.py'] add_cron_job(test_script2,1440)以下是 'crontab -e' 的輸出(注意添加了額外的空格)* * * * * python test1.py # test1.py* * * * * python test2.py # test2.py*/1440 * * * * python test3.py # test3.py當我重新運行 python cron_job 腳本時,它會以某種方式禁用最后一個 cron_job(test3.py),以下是 crontab 文件的輸出:* * * * * python test1.py # test1.py* * * * * python test2.py # test2.py# DISABLED LINE# */1440 * * * * python test3.py # test3.py*/1440 * * * * python test3.py # test3.py連同它在控制臺上拋出的錯誤:No handlers could be found for logger "crontab"所以我的問題是3折:為什么運行 my_cron.write() 時命令頂部有額外的空間?為什么它會禁用最后一個 cron 作業而不是忽略它,因為它已經存在(def cron_exits 應該已經處理好了)拋出的錯誤有什么意義?
1 回答

慕雪6442864
TA貢獻1812條經驗 獲得超5個贊
我運行了您的代碼,并在第二次運行時出現以下錯誤:
'1440', not in 0-59 for Minutes
我將 1440 更改為 14 并多次運行代碼。并且每次都找到相同的代碼(不刪除)
* * * * * python test1.py # test1.py
* * * * * python test2.py # test2.py
*/14 * * * * python test3.py # test3.py
我還沒有閱讀完整CronTab的代碼,但很明顯他們在讀取現有的 cron 命令期間放置了一些驗證器,但他們在寫入期間沒有驗證它。
我也add_cron_job用不同的參數調用,發現每次my_cron.write()調用它都在添加一個新行。這不是一個錯誤,而是一個功能。
最后 No handlers could be found for logger "crontab"是日志記錄問題。試試這個Crontab Logger 問題
添加回答
舉報
0/150
提交
取消