用法:注意是用英文的逗号",",且之间没有空格。
文件名,[工作表名称,不写则默认当前激活的表],[从第几行开始,不写则默认第二行,因为很多表第一行是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()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“Python Excel vlookup函数实现过程解析”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
2024年12月26日
2024年12月26日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]