Python中自动关闭已打开文件脚本
2023-12-27 09:59:16
检测指定位置的excel是否为打开状态,若是打开状态,强制保存并关闭,若是关闭状态,不做处理的逻辑
import psutil
import os
import win32com.client
def is_excel_open(file_path):
for process in psutil.process_iter(['pid', 'name']):
if "EXCEL.EXE" in process.info['name']:
try:
for file in process.open_files():
if os.path.abspath(file_path) == os.path.abspath(file.path):
return True
except (psutil.NoSuchProcess, psutil.AccessDenied, psutil.ZombieProcess):
pass
return False
def save_and_close_excel(file_path):
try:
excel = win32com.client.Dispatch("Excel.Application")
excel.Visible = False
workbook = excel.Workbooks.Open(os.path.abspath(file_path))
workbook.Save()
workbook.Close()
excel.Quit()
except Exception as e:
print(f"Error while saving and closing Excel: {e}")
def process_excel_file(file_path):
if is_excel_open(file_path):
print(f"Excel file {file_path} is open. Saving and closing.")
save_and_close_excel(file_path)
else:
print(f"Excel file {file_path} is closed. No action needed.")
# 示例用法
excel_file_path = "path/to/your/excel/file.xlsx"
process_excel_file(excel_file_path)
这个示例中,is_excel_open 函数用于检测指定位置的 Excel 文件是否被打开。如果文件被打开,save_and_close_excel 函数将使用 win32com.client 来打开文件、保存并关闭。在实际使用中,请确保你已经安装了 psutil 和 pywin32:
pip install psutil pywin32
文章来源:https://blog.csdn.net/m0_57021623/article/details/135208078
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!