文章目录
- 一、文章的目的(适用于windows)
- 二、处理方式
- 三、进程查看的内容在窗口端的演示
- 四、附上代码例子
- 四、通过os.kill的方式,再回到原来的表格时,会出现如下错误提示:
一、文章的目的(适用于windows)
程序中需要对已打开的表格文件进行监控,如果有表格已经打开,不允许打开新的表格。
二、处理方式
使用psutil模块,获取所有任务管理器进程的信息,然后对进程进行名称判断,只要进程已经激活的,不再启动。
三、进程查看的内容在窗口端的演示
四、附上代码例子
例子:要求做打开表格前,先检查电脑中是否已经有表格处于打开状态,如果是,则关闭表格,如果没有,就启动表格。
注:wps的表格属性为et.exe;office的表格属性为EXCEL.EXE
import psutil
import PySimpleGUI as sg
import os
for proc in psutil.process_iter(['pid','name']):
try:
if proc.info['name'] in ['et.exe','EXCEL.EXE']:
sg.popup('有打开的表格文件,现在关闭')
os.kill(proc.info['pid'],9)
sg.popup('表格文件已关闭,现在你可以打开新的表格了。')
except Exception as e:
pass
四、通过os.kill的方式,再回到原来的表格时,会出现如下错误提示:
这里如果要想正常退出表格,可以考虑取消kill的方式,用手动的方式退出,避免未保存的文件丢失。