实际工作中,我们经常会把表格某个区域(如:A1:F5)或某个图形保存为图片,如何用python自动做到这一点?不知屏幕前的小伙伴有没有遇到过类似的需求,此刻脑海里有木有一丢丢思路。

  python操作excel的第三方库有很多,个个都有各自的绝招和擅长的应用场景,简单罗列一下:

  • pyexcel:pyexcel是一个用于读写Excel、CSV和其他文件格式的库,提供了简单易用的接口。
  • pandas-ExcelWriter:这是Pandas库的一个模块,用于将数据写入Excel文件。
  • DataNitro:DataNitro是一个插件,可以在Excel中使用Python脚本,实现数据处理和分析。
  • pyxlsb:pyxlsb是一个用于读取Excel二进制文件(xlsb格式)的库。
  • Pandas:Pandas是一个强大的数据处理库,可以读取、写入和操作Excel文件。
  • OpenPyXL:OpenPyXL是一个专门用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的库。
  • XlsxWriter:XlsxWriter是一个用于写入Excel文件的库,支持Excel 2007 xlsx文件格式。
  • xlrd / xlwt:这两个库分别用于读取和写入Excel文件,支持Excel 2003以前的xls文件格式。
  • pywin32(win32com.client):这个库可以显式(或隐式)地打开excel进行一列操作,语法基本完全沿用VBA中的语法,只需要稍加pythonic改造。

  这些库提供了诸多的功能和特性,几乎涉及到表格处理的方方面面,可以根据项目需求选择最适合的库来处理Excel表格。具体到我们今天的场景,使用win32com.client是最优解,因为它可以用到vba中已经提供的图片类API,比如-复制-选择性粘贴-粘贴为图片。

需要说明的是,为了区域转图片成功,必须做到以下几点:

1、当前工作表处于选中状态;

2、当前区域必须至少部分肉眼可见;

3、当前表格的显示比例需要默认为100%。

为了避免截图后的图片是漆黑(无色)的底色,建议提前将对应单元格区域的背景色设置为白色或者其他颜色。

有了这些前提后,就可以用单元格区域的copyPicture()方法将单元格区域数据写入剪贴板,再借助PIL库的ImageGrab.grabclipboard()方法从剪贴板获取数据,并保存为图片啦。

先看看CopyPicture的语法,如何设置参数。

完整的python示例代码如下:

 1 from PIL import ImageGrab
2 import win32com.client as win32
3 from win32api import RGB
4
5 def capture_sheet_range_to_picture(sheetFilePath,sheetName,sheetRange,imgFilePath):
6 '''从某个excel的某个表中的某个区域截图,并保存为图片
7 sheetRange:str,如:"A1:E100"
8 '''
9 # 启动Excel应用
10 xlApp = win32.Dispatch('Excel.Application')
11 xlApp.Visible=True
12 # 打开目标Excel文件
13 workbook = xlApp.Workbooks.Open(sheetFilePath)
14 # 选择指定的工作表
15 detailSheet = workbook.Sheets(sheetName)
16 xlApp.ActiveWindow.ScrollRow = 2 #将水平滚动条拉到最上方
17 xlApp.ActiveWindow.ScrollColumn = 2
18 xlApp.ActiveWindow.Zoom = 100 # 调整表格的缩放为100%显示
19
20 detailSheet.Range(sheetRange).Interior.Color = RGB(255,255,255) # 纯白色
21 time.sleep(0.3)
22 # 将区域复制为图片
23
24 try:
25 detailSheet.Range(sheetRange).CopyPicture(1,2)
26 img = ImageGrab.grabclipboard() # 获取图片数据
28 img.save(imgFilePath)
29 except Exception as e:
30 # 如果截图失败,则重试一次
31 time.sleep(0.3)
32 detailSheet.Range(sheetRange).CopyPicture(1,2)
33 img = ImageGrab.grabclipboard() # 获取图片数据
34 img.save(imgFilePath)
35 # 关闭工作簿并退出Excel
36 workbook.Close(SaveChanges=False)
37 xlApp.Quit()
38 return

  这段代码【信息量】很大,您可别不信,都是小爬我一遍遍踩坑才得来的宝贵经验哟,相信您已经受到了不少启发,那就动手试试吧,一定会收获满满。

快来关注本公众号 获取更多爬虫、数据分析的知识!

使用python对Excel表格某个区域保存为图片的更多相关文章

  1. python 对Excel表格的写入

    python对Excel表格写入需要导入xlrd ,和xlutils两个库 from xlrd import open_workbook from xlutils.copy import copy o ...

  2. Python 利用Python操作excel表格之openyxl介绍Part2

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart()    ...

  3. Python 利用Python操作excel表格之openyxl介绍Part1

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...

  4. 【转】python操作excel表格(xlrd/xlwt)

    [转]python操作excel表格(xlrd/xlwt) 最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异, ...

  5. Python 利用Python操作excel表格之xlwt介绍

    利用Python操作excel表格之xlwt介绍   by:授客 QQ:1033553122 直接上代码   案例1 #!/usr/bin/env python # -*- coding:utf-8 ...

  6. Python读写Excel表格

    最近在做一些数据处理和计算的工作,因为数据是以.CSV格式保存的,因此刚开始直接用Excel来处理. 但是做着做着发现重复的劳动,其实并没有多大的意义,于是就想着写个小工具帮着处理. 以前正好在一本书 ...

  7. python - 操作excel表格

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  8. 转载:python操作excel表格(xlrd/xlwt)

    python操作excel表格(xlrd/xlwt)   最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而 ...

  9. Python读取Excel表格

    前言:需要进行自动化办公或者自动化测试的朋友,可以了解下此文,掌握Python读取Excel表格的方法. 一.准备工作: 1.安装Python3.7.0(官网下载安装包) 2.安装Pycharm(官网 ...

  10. python 处理 Excel 表格

    see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...

随机推荐

  1. INFINI Easysearch 与华为鲲鹏完成产品兼容互认证

    何为华为鲲鹏认证 华为鲲鹏认证是华为云围绕鲲鹏云服务(含公有云.私有云.混合云.桌面云)推出的一项合作伙伴计划,旨在为构建持续发展.合作共赢的鲲鹏生态圈,通过整合华为的技术.品牌资源,与合作伙伴共享商 ...

  2. PowerShell 遇到 .ps1,因为在此系统上禁止运行脚本

    PowerShell 遇到 .ps1,因为在此系统上禁止运行脚本 解决方法: 以管理员身份打开PowerShell: 查看当前的执行策略: Get-ExecutionPolicy * `Restric ...

  3. docker registry 镜像源

    修改文件 /etc/docker/daemon.json vi /etc/docker/daemon.json添加以下内容后,重启docker服务: { "registry-mirrors& ...

  4. JsonPath - 根据表达式路径解析Json

    JsonPath 在xml的使用过程中,对于xml的解析我们知道可以使用xpath的方式,随意的获取到我们想要的属性值.那么在使用json时,我们能不能实现同样的操作呢? 答案就是 json-path ...

  5. IT运维全面数字化|芯片设计行业领跑打造运维流程闭环

    在当今数字化转型的浪潮中,科技行业正经历着前所未有的变革.随着5G.人工智能.物联网等新兴技术的快速发展,企业对于高效.智能的运营模式的需求日益迫切. 芯片设计公司作为科技产业链中的关键一环,不仅要在 ...

  6. opencv在MAC下的安装

    版本信息 MAC版本:10.10.5 Xcode版本:7.2 openCV版本:2.4.13 安装步骤: 联网 安装brew,在终端输入指令 /usr/bin/ruby -e "$(curl ...

  7. CAP 8.2 版本发布通告

    前言 今天我们很高兴宣布 CAP 发布 8.2 版本正式版,我们在这个版本中主要致力于对订阅着并行执行的特性提供支持,同时添加了对在订阅者中对消息头的控制行为. 下面,具体看一下我们新版本的功能吧. ...

  8. 在Linux应用层使用POSIX定时器

    在Linux应用层使用POSIX定时器 ref : http://blog.chinaunix.net/uid-28458801-id-5035347.html http://blog.sina.co ...

  9. RabbitMQ 3.7.9版本中,Create Channel超时的常见原因及排查方法

    在RabbitMQ 3.7.9版本中,Create Channel超时的常见原因及排查方法如下: 常见原因 网络问题: 网络延迟或不稳定可能导致通信超时. 网络分区(network partition ...

  10. throws和try catch的区别

    1.throws是表明方法抛出异常,需要调用者来处理,如果不想处理就一直向外抛,最后会有jvm来处理: 2.try catch 是自己来捕获别人抛出的异常,然后在catch里面去处理: 一般情况下,第 ...