利用python对excel进行截图并保存的时候,经常性出现excel没有正常关闭,导致截图失败。源代码如下:
# -*- coding:utf-8 -*-
Datetime:2019/12/30 11:45
Author:sys
from win32com.client import Dispatch, DispatchEx
import pythoncom,os
from PIL import ImageGrab, Image
import uuid
#coding:utf-8
screen_area——类似格式"A1:J10"
'''
函数参数名:filename:需要截图的文件名和路径
sheetname:需要截图的文件的sheet名称
save_image_name:截图后保存的图片名称,格式为save_image_name.png
'''
def Excel_Catch_Screen(filename, sheetname ,save_image_name):
""" 对excel的表格区域进行截图——用例:"""
filename = os.path.abspath(filename)
pythoncom.CoInitialize() # excel多线程相关
excel = DispatchEx("Excel.Application") # 启动excel
#del excel #这个地方很重要,杀死excel进程是这个地方起作用
excel.Visible = False # 不显示Excel,而True可视化
excel.DisplayAlerts = True # 是否显示警告,关闭系统警告(保存时不会弹出窗口)
workbook = excel.workbooks.Open(filename) # 打开excel
sheet = workbook.worksheets[sheetname] # 选择sheet
screen_area = sheet.UsedRange #有内容的区域
screen_area.CopyPicture() # 复制图片区域
sheet.Paste() # 粘贴
#img_name='告警截图'
img_name=save_image_name
excel.Selection.ShapeRange.Name = img_name # 将刚刚选择的Shape重命名,避免与已有图片混淆
sheet.Shapes(img_name).Copy() # 选择图片
img = ImageGrab.grabclipboard() # 获取剪贴板的图片数据
print(img) # 可以弄个报错
img.save(img_name + '.png') # 保存图片
#workbook .Close(SaveChanges=0) # 关闭工作薄,不保存
workbook.Close(False) # 关闭Excel文件,不保存
excel.Quit() # 退出excel
del excel #这个地方很重要,杀死excel进程是这个地方起作用
pythoncom.CoUninitialize() # 关闭多线程
os.remove(filename)
if name == '__main__':
#pass
filename = "excel_output.xls"
sheetname = 'Sheet1'
Excel_Catch_Screen(filename,sheetname,'告警截图')
#删除文件
出现的告警如下图所示:
这该怎么处理啊?