Python也可以实现Excel中的“Vlookup”函数?

日常学python

共 2420字,需浏览 5分钟

 · 2022-08-09

VLOOKUP函数大家应该都很熟悉吧,它可以帮我们根据指定的条件快速查找匹配出相应的结果,通常被用于核对、匹配多个表格之间的数据。与数据透视表,并称为数据er最常用的两大Excel功能。
07599adb2978adc1dca2558c17f4cf8e.webp

那我们今天就聊聊,如何Python写Excel中的“Vlookup”函数?

Excel

如图所示,在“测试工资数据.xlsx”表格文件中有两个sheet,其中sheet1是我们的数据源区域,而sheet2存储的是待查找的员工姓名和工资。

652083b02b91763de92faaa9822a986c.webp

在sheet2中,一列是员工姓名,一列是他们的对应工资。

ca8d459710c6a8d7e5a5fa57ceae8be5.webp

vlookup函数就是在表格或数值数组的首列查找指定的数值,并由此返回表格或数组当前行中指定列处的数值。语法格式如下所示:

VLOOKUP (lookup_value, table_array, col_index_num, [range_lookup])

对应在本次案例中的使用,如下图所示。

6f3716859eaf25fb3da23e0abfe712f9.webp

一般是匹配条件容易记混,如果为FALSE或0,则返回精确匹配,如果找不到,则返回错误值 #N/A。如果 range_lookup 为TRUE或1,函数 VLOOKUP 将查找近似匹配值。

openpyxl

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

pip install openpyxl

在openpyxl中,读取已有的Excel文件,使用到的是load_workbook类,因此需要提前导入这个类。接着,实例化load_workbook("测试工资数据.xlsx")对象,得到一个工作簿对象。

然后,使用workbook["Sheet2"]激活该工作簿中的Sheet2表,表示我们要针对这个表进行操作。完成上述操作后,下面就可以进行vlookup公式的填写了。[1]

from openpyxl import load_workbook 

workbook = load_workbook("测试工资数据.xlsx")
sheet = workbook["Sheet2"]

sheet["B1"] = "基本工资(Python)"
for i in range(2, sheet.max_row+1): 
    sheet[f"B{i}"] = f'=VLOOKUP(A{i},Sheet1!A:B,2,FALSE)'
workbook.save(filename = "vlookup.xlsx")

首先,我们利用sheet["B1"] = "基本工资(Python)"修改B1单元格位置的表头。然后通过for循环语句,循环第2行到最后一行,针对每一个B列单元格,我们都写入上述vlookup公式。最后记得保存一下即可。

d534c7e4edbc08334f911649848fbc28.webp

不过需要注意,Python操作Excel的优势在于处理大数据、或者重复性工作。在本次案例中,使用openpyxl库向Excel中写入Vlookup函数多少有点大材小用了。

经过openpyxl一番操作,如同庄周带净化。

Pandas

在这数据爆炸的时代,我们无时无刻不在和数据打交道。面对杂乱无章的数据Pandas 模块应运而生了,它提供了数据导入、数据清洗、数据处理、数据导出等一套流程方法,可以很方便地帮助我们自动整理数据[2]。

那么Excel中的这种常用函数,Pandas模块自然也是可以轻松搞定了。

12e67e96da5daa4e28537558433c09f3.webp▲《快学Python:自动化办公轻松实战》

在 Pandas 模块中,调用merge()方法,可以帮助我们实现数据连接。

在交互式环境中输入如下命令:

import pandas as pd
path = "测试工资数据.xlsx"
df_1 = pd.read_excel(path, sheet_name = 'Sheet1')
df_2 = pd.read_excel(path, sheet_name = 'Sheet2')

pd.merge(df_2["姓名"], df_1[["姓名""基本工资"]], how="left", on="姓名")

输出结果:

1e41bfd36a9a789c58c92d284fcace4c.webp

这样我们就用Python(openpyxl + Pandas)实现了Excel中的“Vlookup”函数。


往期推荐

终于来了,  彭涛Python 爬虫训练营 ! 本周最低价,这次千万别错过了!

Python 文本终端 GUI 框架,太酷了!

微软继续拆分VS Code Python扩展,再推三款独立扩展

当编程纳入到高考。。。

对比3款Pandas可视化GUI界面工具,再见吧,Excel!

我们开发了一门爬虫课,从0到1带大家学习 Python 爬虫,既可以做副业接单,也可以做爬虫工程师,欢迎扫码了解。

具体看:终于来了,  彭涛Python 爬虫训练营 !


长按扫码,可以试听,想了解爬虫更多细节可以添加「257735


浏览 31
点赞
评论
收藏
分享

手机扫一扫分享

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

手机扫一扫分享

举报