python脚本-使用schedule库 定时任务执行不同脚本,并将各脚本的print统一输出

注释都有,看代码

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秒检查一次

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值