Python Excel vlookup函数实现过程解析
作者:wztshine 时间:2022-05-24 06:12:07
用法:注意是用英文的逗号",",且之间没有空格。
文件名,[工作表名称,不写则默认当前激活的表],[从第几行开始,不写则默认第二行,因为很多表第一行是title],列名(第一列是要查找的元素,列名可以不连续,比如“ade”)
脚本会自动把要查找的第一列进行大小写变换,去除空格等操作,下面的例子中,第一列的名字有的是大写,有的小写,前后还有空格,脚本会默认它们相同
现有Sheet1,内容如下
Sheet2内容如下
想把 Sheet1 的 B,C 列的信息复制到 Sheet2 的 B,C列上,执行脚本:
Source fileName,[sheetName],[row],columns:
vlookup.xlsx,Sheet1,1,abc
Target fileName,[sheetName],[row],columns:
vlookup.xlsx,Sheet2,1,abc
{'name': ['Lao Wang', 'Zhang San'], 'age': [23, 25], 'id': [23429234, None], 'phone': ['18292942422', '1000101010'], 'addr': ['BeiJIng', None]}
{'addr': [None, None], 'phone': [None, None], 'id': [None, None], 'age': [None, None], 'name': [None, None]}
Processing...
Done.
然后Sheet2的内容就变成了:
import openpyxl
def read_Excel(path,sheetName,row,*col):
# 默认从第二行开始,因为很多表都有表头
if row == '':
row = 2
else:
row = int(row)
workbook = openpyxl.load_workbook(path)
# 默认打开当前激活的工作表
if sheetName == "":
sheet0 = workbook.active # 获取当前激活的工作表
else:
sheet0 = workbook[sheetName] # 如果制定了工作表,就打开指定的工作表
highest = sheet0.max_row
case_list = {}
# title 所在列,对比的那一列,假设A列
title = col[0]
for i in range(row,highest+1): # 遍历行
value_list = []
if sheet0[title+str(i)].value == None: # 如果A5是空的,pass
pass
else:
v1 = sheet0[title+str(i)].value.lower().strip() # 忽略大小写和前后空格
# 除去 title的其他列
for j in range(1,len(col)):
v2 = sheet0[col[j]+str(i)].value
value_list.append(v2)
case_list[v1] = value_list
print(case_list)
return case_list
def write_Excel(dict,path,sheetName,row,*col):
# 将处理好的数据再次写入excel
if row == "":
row = 2
else:
row = int(row)
workbook = openpyxl.load_workbook(path)
if sheetName == "":
sheet0 = workbook.active # 获取当前激活的工作表
else:
sheet0 = workbook[sheetName]
highest = sheet0.max_row
# case title 所在列
title = col[0]
for i in range(row,highest+1):
if sheet0[title + str(i)].value != None:
v1 = sheet0[title + str(i)].value.lower().strip() # 忽略大小写和前后空格
for key in dict:
if key == v1:
for j in range(1,len(col)):
v2 = sheet0[col[j]+str(i)]
v2.value = dict[key][j-1]
workbook.save(path)
def process(r1,r2):
# 对比处理两次读取的内容,然后更新r2的内容
print('Processing...')
for key in r1:
if key in r2:
length = len(r1[key])
if length > 0:
for i in range(0, len(r1[key])):
# 如果想要不想覆盖原有的数值,可以取消注释,然后删除下面那行
# if r2[key][i] == None:
# r2[key][i] = r1[key][i]
r2[key][i] = r1[key][i]
else:
pass
return r2
def manual():
info1 = input('Read from fileName,[sheetName],[row],columns:\n')
file1,sheetName1,row1,list1 = info1.split(',')
info2 = input('Write into fileName,[sheetName],[row],columns:\n')
file2,sheetName2,row2,list2 = info2.split(',')
r1 = read_Excel(file1,sheetName1,row1,*list1)
r2 = read_Excel(file2,sheetName2,row2,*list2)
r3 = process(r1,r2)
write_Excel(r3,file2,sheetName2,row2,*list2)
print('Done.')
if __name__ == "__main__":
manual()
来源:https://www.cnblogs.com/wztshine/p/13168235.html
标签:Python,Excel,vlookup,函数
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
SQL Server中实现二进制与字符类型之间的数据转换
2023-07-17 21:34:47
SQL学习笔记二 创建表、插入数据的语句
2011-09-30 11:17:32
Python设计模式中的行为型策略模式
2023-02-28 17:04:25
![](https://img.aspxhome.com/file/2023/3/113063_0s.png)
python基本数据类型练习题
2022-07-21 14:26:26
![](https://img.aspxhome.com/file/2023/6/98996_0s.png)
Python最基本的数据类型以及对元组的介绍
2022-03-26 07:04:07
Python中对列表排序实例
2021-12-05 17:41:28
Python中格式化字符串输出的4种方式小结
2023-08-10 21:30:49
教你如何使用Python开发一个钉钉群应答机器人
2023-08-03 17:44:16
![](https://img.aspxhome.com/file/2023/5/61225_0s.gif)
详解如何通过Mysql的二进制日志恢复数据库数据
2024-01-19 11:33:43
![](https://img.aspxhome.com/file/2023/8/79998_0s.png)
pygame实现简单五子棋游戏
2022-03-22 08:50:57
CI框架中数据库操作函数$this->db->where()相关用法总结
2024-06-05 09:45:16
javascript eval和JSON之间的联系
2024-04-19 10:00:51
python 使用事件对象asyncio.Event来同步协程的操作
2023-02-24 12:46:41
python中分组函数groupby和分组运算函数agg的使用
2023-05-25 03:15:48
Python变量赋值的秘密分享
2021-10-12 11:53:04
![](https://img.aspxhome.com/file/2023/9/98889_0s.png)
python 移除字符串尾部的数字方法
2023-03-18 19:38:21
用XMLHTTP很好的一个例子
2008-04-25 10:25:00
JavaScript 获取客户端计算机硬件及系统信息
2009-01-13 17:59:00
![](https://img.aspxhome.com/file/UploadPic/20091/13/200901081050518738-49s.gif)
关于mysql查询字符集不匹配问题的解决方法
2024-01-27 23:53:06
如何尽快释放掉Connection对象建立的连接?
2009-12-16 18:38:00