Python Excel vlookup函数实现过程解析
时间:2022-07-27
本文章向大家介绍Python Excel vlookup函数实现过程解析,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
用法:注意是用英文的逗号”,”,且之间没有空格。
文件名,[工作表名称,不写则默认当前激活的表],[从第几行开始,不写则默认第二行,因为很多表第一行是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()
以上就是本文的全部内容,希望对大家的学习有所帮助。
- 快速排序
- 2017.7.21夏令营清北学堂解题报告
- P3386 【模板】二分图匹配
- √n求单值欧拉函数
- 模板语言
- Django 相关
- 装饰器进阶
- P2894 [USACO08FEB]酒店Hotel
- 深入理解计算机系统读书笔记之第一章:漫游
- 【实战】工控网络协议模糊测试:用peach对modbus协议进行模糊测试
- 【Django错误】OSError: raw write() returned invalid length 14 (should have been between 0 and 7)
- P2234 [HNOI2002]营业额统计
- Python 中格式化字符串 % 和 format 两种方法之间的区别
- [实战]如何在Kali Linux中进行WIFI钓鱼?
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux初学(CnetOS7 Linux)之切换命令模式和图形模式的方法
- linux expect 自动登录交换机保存配置的方法
- CentOS7安装mysql5.7解压缩版简明教程
- Gunicorn Django部署配置方法
- Linux中使用NTP保持精确时间的方法详解
- LNMP环境下搭建yum的方法分析
- django 利用pillow 进行简单的设置验证码功能(python)
- Centos环境下安装Zend optimizer 3.3.9的方法
- Linux curl表单登录或提交与cookie使用详解
- Linux磁盘设备与LVM管理命令示例详解
- Ubuntu基础教程之apt-get命令
- Ubuntu18.04.2下安装 RTX2080 Nvidia显卡驱动的方法
- linux进程监控与自动重启的简单实现方法
- Linux 解决Deepin无法在root用户启动Google Chrome浏览器的问题
- 在Linux上安装和使用Docker的方法