python启动服务和进程,优雅的日志框架,好用的定时任务组件,在代码执行bat和exe不d黑框

python启动服务和进程,优雅的日志框架,好用的定时任务组件,在代码执行bat和exe不d黑框,第1张

踩坑记录
  1. 在windows通过注册服务调用批处理是无法唤起windows视窗的,也无法识别%appdata%,%userprofile%这样的相对路径,视窗可以通过进程去调,而相对路径的写法,必须换为绝对路径
  2. 目前一般采用loguru作为python日志功能实现,用法比较符合使用java开发者的习惯
  3. 定时任务尽量不要使用schedule实现,使定时任务常驻cpu不太合理,而是使用sched
  4. os.system(),subprocess.run(XXX,shell=True),subprocess.run(XXX,shell=False)会d出黑框

话不多说,看代码

  1. windows开启服务
import win32service
from loguru import logger

# 开启服务
def start_service(name): #严格的服务名作为传参
    try:
        hSCManager = win32service.OpenSCManager(None, None, win32service.SC_MANAGER_ALL_ACCESS)
        handle = win32service.OpenService(hSCManager, name, win32service.SC_MANAGER_ALL_ACCESS)
        if handle:
            win32service.StartService(handle, None)
            win32service.CloseServiceHandle(handle)
            return True
    except Exception as e:
        logger.warning("重启服务异常:{}", e)

  1. 设置定时任务
import sched
from loguru import logger

def job():
	logger.warning("我使每60秒执行一次的定时任务")

job_handler = sched.scheduler(time.time, time.sleep)
# 此处添加任务
def perform(inc):
    job_handler.enter(inc, 0, perform, (inc,))
    job()
    
# 60秒一次,此函数在业务逻辑调用
def sheduled_job(inc=60):
    # 定时任务
    job_handler.enter(0, 0, perform, (inc,))
    job_handler.run()
    
  1. 启动进程
import os

progress_path = "C:/python3810"
def startProgress():
	
	os.chdir(progress_path)
	# 使用绝对路径
	os.popen(progress_path + '\python.exe')
	
  1. 不d黑框,这里好记,统一用subprocess,脚本是run,exe是Popen
import subprocess
import os

def open_bat(bat_path):
	#config = subprocess.STARTUPINFO
	#config.dwFlags = subprocess.STARTF_USESHOWWINDOW
	#config.wShowWindow = subprocess.SW_HIDE
	#subprocess.Popen(command, startupinfo=config) #备用
	
	subprocess.run(command, shell=True)  #首选

def open_exe(exe_path):
	
	subprocess.Popen(exe_path, shell=True) #首选
	
	os.popen(exe_path) #亦可用

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/714926.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-25
下一篇 2022-04-25

发表评论

登录后才能评论

评论列表(0条)

保存