Python中也可以写Excel中的“Vlookup”函数?太牛逼了吧!

林骥

共 1949字,需浏览 4分钟

 ·

2020-12-09 00:04

你好,我是林骥。
以前我写过一篇文章:
用Python自动生成Excel报表
其中介绍了用 openpyxl 操作 54 0000 多行的交易数据,并自动生成报表的方法和步骤。
当数据量很大的时候,在 Excel 中使用大量的公式,速度可能会很慢,特别是当电脑配置不够的时候。
记得有一次,在两个 Excel 表中,都有差不多 100 0000 行的数据,我要对它们进行匹配计算,通过双击下拉公式的时候,电脑就卡死了,运行了十几分钟,还是没有计算出想要的结果。
后来我借助 Python 来操作 Excel,速度就明显快了很多,所以我常说,Python 是提升数据分析工作效率的利器。
下面推荐一种 Python 与 Excel「双剑合璧」的方法,希望能够对你有所启发。

·  正  ·  文  ·  来  ·  啦  · 

Vlookup函数,可以算是一个数据专员必须要会使用的基本函数了,确实很好用。但是你可能会注意到,Excel一旦数据量过大,打开都费劲了,何况打开后,你还要输入公式计算,就更费劲了,此时你有没有想到过被称作“万金油”的Python,他好像啥都可以做,是不是很牛逼?对于Excel来说的大数据量,但是对于Python来说,应该是小菜一碟。今天我就带着大家对比学习一下,怎么分别在Excel和Python中使用Vlookup函数。

数据源介绍

如图所示,有一个“vlookup.xlsx”文件,“A1:F11”是我们的数据源区域,“K1:L5”是我们的查找源区域。我们的目的就是要在数据源区域的G列加一列数据,查找出不同类型下名称表示。

Vlookup函数介绍

这个函数我想大家应该都会,大家应该也不需要我介绍的太详细,因此我就简单的为大家介绍一下vlookup函数的语法。
  • 参数说明:vlookup(待查找目标, 查找区域, 匹配值所在的列, 精确匹配OR模糊查找);
  • 用一句通俗的话来说明vlookup函数的用法:针对每一个待查找目标,它就能从指定的查找区域中,查找返回想要查找到的值。

Excel中使用Vlookup函数

针对上述提到的数据源,了解Vlookup函数的语法后,下面来看看如何在Excel中使用Vlookup函数。
观察上图:首先,我们在G1单元格新增了一个“名称”列。接着,在G2单元格我们写了一个vlookup公式,E2表示每一个待查找值,K1:L5表示待查找区域,我们使用F3快捷键将这个区域变为了绝对引用,因为我们的查找区域就是这一个固定范围,2表示待返回值在查找区域中所在的列数,0表示精确匹配。
最后,使用填充柄下拉填充即可。

Python中使用Vlookup函数

在Python中利用openpyxl库,就可以完成公式的填充。因此在使用openpyxl之前,需要使用pip install openpyxl安装好这个库。
from openpyxl import load_workbook 

workbook = load_workbook("vlookup.xlsx")
sheet = workbook["Sheet1"]

sheet["G1"] = "名称"
for i in range(2,sheet.max_row+1): 
    sheet[f"G{i}"] = f'=VLOOKUP(E{i},$K$1:$L$5,2,0)'
workbook.save(filename = "vllokup1.xlsx")
在openpyxl中,读取已有的Excel文件,使用到的是load_workbook类,因此需要提前导入这个类。接着,实例化load_workbook("vlookup.xlsx")对象,得到一个工作簿对象。然后,使用workbook["Sheet1"]激活该工作簿中的Sheet1表,表示我们要针对这个表进行操作。完成上述操作后,下面就可以进行vlookup公式的填写了。
首先,我们利用sheet["G1"] = "名称"给G1单元格增加了一个表头。然后写了一个循环,循环第2行到最后一行,针对每一个G列单元格,我们写入上述vlookup公式。最后记得保存一下即可。

用Python自动生成数据分析报告


如何用Python自动操作数据库?


如何自动发送一封得体的邮件?


长按下方的二维码,关注林骥的公众号,更多干货早知道。
欢迎加入我的免费知识星球,我每天都会在星球内分享读书笔记和思考感悟,点击左下角的阅读原文即可加入。
浏览 23
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报