前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >自动化办公 | 快速从Excel中提取图片并匹配命名

自动化办公 | 快速从Excel中提取图片并匹配命名

作者头像
朱小五
发布2021-04-21 16:53:02
4.7K1
发布2021-04-21 16:53:02
举报
文章被收录于专栏:凹凸玩数据凹凸玩数据

大家好,我是小五?

关于自动化办公,之前我思考过好久。到底什么是自动化办公,哪些属于能真正提高我们工作效率的知识,哪些所谓的python自动化办公项目又是伪需求?

其实挺难断定的,可能大部分人用不到的一个功能,对于刚需的人却是救命稻草!

比如今天的这个需求?

案例需求

一个群友在交流群里提出了这样一个问题

这是他给出的示例文件,其中F列的商品编码,G列是商品图片。希望能够将G列的图片提取出来,并以同行的F列商品编码命名。

下面给大家讲讲,如何轻松提取Excel的图片?

最简单的解决办法

其中最简单的办法就是:将原Excel文件后缀名改为压缩包格式(zip、rar等)

这时候只需要解压此压缩包,再依次打开【xl】→【media】文件夹,就可以看到一堆图片。

这些图片就是原本Excel中插入的图片。

是不是很简单?网上python自动化提取Excel中图片的方法,其基本原理也是一样的。

所以大家如果遇到了这种需求,不妨先试试这种方法(包括在Word中提取图片也是同理)

但是这种解决办法在本案例中并不适用。

为什么呢?

整个Excel中有重复的图片,这就会导致压缩包解压后的图片会自动去重,这样我们就没办法给图片匹配命名。

一共126行商品数据,但解压后只提取出了112张图片。

下面继续带大家尝试用不同办法解决这个问题?

VBA 方法

有群友给出了VBA的解法:

先看实现的效果动图

这里公布VBA代码,刚兴趣的同学可以自己学习研究一下

代码语言:javascript
复制
Sub 导出图片()
    On Error Resume Next
    MkDir ThisWorkbook.Path & "\图片"
    For Each pic In ActiveSheet.Shapes
        If pic.Type = 13 Then
            RN = pic.TopLeftCell.Offset(0, -1).Value
            pic.Copy
            With ActiveSheet.ChartObjects.Add(0, 0, pic.Width, pic.Height).Chart    '创建图片
                .Parent.Select
                .Paste
                .Export ThisWorkbook.Path & "\图片\" & RN & ".jpg"
                .Parent.Delete
            End With
        End If
    Next
End Sub

既然VBA能实现,那自动化办公的另一个巨头——python哥也不能说不行啊。

Python方法

我们可以使用openpyxl来自动提取Excel中的数值,但是对于单元格里的图片就束手无策了。

毕竟它是浮动的。

这里我们需要再安装一个库——openpyxl-image-loader来搭配使用。顾名思义,它的功能就是从单元格获取图像,正好可以实现我们的需求。

表情包(真不错)

具体实现语句如下所示:

代码语言:javascript
复制
path = r'D:\python_code\\'
saveDir = "图片/"

wb = load_workbook(path + '待收集图片sku.xlsx')
ws = wb['Sheet1']
image_loader = SheetImageLoader(ws)

num = ws.max_row
for i in range(2,num+1):
    name = ws['F'+str(i)].value
    image = image_loader.get('G'+str(i))
    image.save(saveDir + name + ".png")

其中image_loader.get()函数就是用来获取单元格的图像,我们只需再将openpyxl获取的F列商品编号作为图片名保存即可。

运行后的结果

可以看到,标注圈出的图片原本是相同的,但仍然被命名为对应的商品编号,这样我们最终提取并命名的图片也就是126张。

说明我们同样解决了这个需求!

所以无论VBA还是python,只要能真正解决我们实际问题的,都是自动化办公的好帮手

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-04-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 凹凸数据 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 案例需求
  • 最简单的解决办法
  • VBA 方法
  • Python方法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档