在windows系统中,双击运行python程序以及后台运行python程序的方法如下:
一、如何避免双击运行*.py文件时的闪退?
- 使用批处理文件启动
在start_show.bat文件中:
python main.py
- 升级版:使用VBS脚本在后台运行
在start_hidden.vbs文件中:
Set ws = CreateObject("Wscript.Shell")
ws.run "cmd /c start_show.bat", 0二、如何在Windows中快速终止Python程序?
立即学习“Python免费学习笔记(深入)”;
使用批处理文件终止:
在stop_all_python.bat文件中:
taskkill /IM python.exe /F
附录:
main.py文件内容:
Co.MZ 是一款轻量级企业网站管理系统,基于PHP+Mysql架构的,可运行在Linux、Windows、MacOSX、Solaris等各种平台上,系统基于ThinkPHP,支持自定义伪静态,前台模板采用DIV+CSS设计,后台界面设计简洁明了,功能简单易具有良好的用户体验,稳定性好、扩展性及安全性强,可面向中小型站点提供网站建设解决方案。
import os
import logging
import time
<h1>如果日志文件夹不存在,则创建</h1><p>log_dir = "log" # 日志存放文件夹名称
log_path = os.getcwd() + os.sep + log_dir
if not os.path.isdir(log_path):
os.makedirs(log_path)</p><h1>设置logging</h1><p>logger = logging.getLogger()
logger.setLevel(logging.DEBUG)</p><p>main_log_handler = logging.FileHandler(
log<em>dir + "/dd</em>%s.log" % time.strftime("%Y-%m-%d_%H-%M-%S", time.localtime(time.time())),
mode="w+",
encoding="utf-8"
)
main_log_handler.setLevel(logging.DEBUG)</p><p>formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
main_log_handler.setFormatter(formatter)
logger.addHandler(main_log_handler)</p><h1>控制台打印输出日志</h1><p>console = logging.StreamHandler() # 定义一个StreamHandler,将INFO级别或更高的日志信息打印到标准错误,并将其添加到当前的日志处理对象
console.setLevel(logging.INFO) # 设置要打印日志的等级,低于这一等级,不会打印
formatter = logging.Formatter("%(asctime)s - %(levelname)s: %(message)s")
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)</p><p>while True:
time_stamp = time.time()</p><h1>print("时间戳",time_stamp)</h1><pre class="brush:php;toolbar:false;"><code>logger.info("时间戳 %s" % time_stamp)
sec = 3
logger.info("睡眠 %s 秒" % sec)
time.sleep(sec)</code>文件截图:

使用说明:
- 带界面双击启动
双击start_show.bat,会出现CMD窗口,同时会生成日志文件夹。


- 不带界面后台运行程序
双击start_hidden.vbs,进程会增加一个python.exe进程,增加的python.exe进程为后台启动的,可以通过日志查看。


- 杀死所有Python.exe进程
双击stop_all_python.bat,所有的Python进程都会消失,第1步中产生的CMD窗口也将消失。











