注释都有,看代码
import subprocess,schedule
import sys,time,datetime,logging
sys.path.append(r'D:\python_test\PycharmProjects\test\wh')
import msg_push,wh_time
# 设置日志输出路径,引用 时间函数和消息通知函数
logging.basicConfig(filename='C:\\Users\\47651\\Desktop\\wh_job.log', level=logging.INFO,format='%(asctime)s - %(levelname)s - %(message)s')
url = "https://open.feishu.cn/open-apis/bot/v2/hook/5eXXXX3" # 飞书机器人地址
work_time_check = wh_time.WhTime()
push_msg = msg_push.MsgPush()
def run_job(job_path,workday="workday"):
try:
logging.info(f"--------------------------------------------------\n【定时执行】开始运行脚本: {job_path}")
formatted_date = datetime.datetime.now().strftime("%Y-%m-%d")
work_status,work_msg = work_time_check.work_time(formatted_date) # 调用工作日查询函数,work_status:0工作日 1休息日
if workday == "workday" and work_status == 1:
logging.info("脚本跳过执行:脚本要求工作日执行,当天为休息日")
else:
command = [r"D:\python_test\PycharmProjects\venv\Scripts\python.exe",job_path]
process = subprocess.Popen(command, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
for line in process.stdout: # 读取脚本的输出 并记录
# decoded_line = line.decode().strip()
decoded_line = line.decode('gbk').strip() # 解码,视‘子进程输出的编码’调整
logging.info(decoded_line)
process.wait()
except Exception as e:
logging.error(f"error脚本执行错误!!!!!异常内容: {e}")
push_msg.feishu_msg(url,'error脚本执行错误,请核查日志!!!!!')
# 设置定时任务list
schedule.every().day.at("09:55").do(run_job, r"D:\python_test\PycharmProjects\test\wh\job\111.py") # 每天9点55分执行(默认工作日)
schedule.every().day.at("09:58").do(run_job, r"D:\python_test\PycharmProjects\test\wh\job\111.py")
schedule.every().day.at("21:00").do(run_job, r"D:\python_test\PycharmProjects\test\wh\job\222.py")
if __name__ == "__main__":
while True:
schedule.run_pending()
time.sleep(20) # 每20秒检查一次