Python中自动关闭已打开文件脚本

检测指定位置的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
  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今晚务必早点睡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值