Python Excel vlookup函数实现过程解析


Posted in Python onJune 22, 2020

用法:注意是用英文的逗号",",且之间没有空格。

文件名,[工作表名称,不写则默认当前激活的表],[从第几行开始,不写则默认第二行,因为很多表第一行是title],列名(第一列是要查找的元素,列名可以不连续,比如“ade”)

脚本会自动把要查找的第一列进行大小写变换,去除空格等操作,下面的例子中,第一列的名字有的是大写,有的小写,前后还有空格,脚本会默认它们相同

现有Sheet1,内容如下

Python Excel vlookup函数实现过程解析

Sheet2内容如下

Python Excel vlookup函数实现过程解析

想把 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的内容就变成了:

Python Excel vlookup函数实现过程解析

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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
以Flask为例讲解Python的框架的使用方法
Apr 29 Python
详解Django中的ifequal和ifnotequal标签使用
Jul 16 Python
Python连接mysql数据库的正确姿势
Feb 03 Python
Linux中Python 环境软件包安装步骤
Mar 31 Python
详解Python编程中对Monkey Patch猴子补丁开发方式的运用
May 27 Python
python安装numpy&安装matplotlib& scipy的教程
Nov 02 Python
python清理子进程机制剖析
Nov 23 Python
浅谈python实现Google翻译PDF,解决换行的问题
Nov 28 Python
Django认证系统实现的web页面实现代码
Aug 12 Python
Python2.7:使用Pyhook模块监听鼠标键盘事件-获取坐标实例
Mar 14 Python
python实现密码验证合格程序的思路详解
Jun 01 Python
简单且有用的Python数据分析和机器学习代码
Jul 02 Python
宝塔面板成功部署Django项目流程(图文)
Jun 22 #Python
python和php哪个更适合写爬虫
Jun 22 #Python
如何理解python对象
Jun 21 #Python
什么是python的必选参数
Jun 21 #Python
什么是python的自省
Jun 21 #Python
python的json包位置及用法总结
Jun 21 #Python
为什么相对PHP黑python的更少
Jun 21 #Python
You might like
PHP $_SERVER详解
2009/01/16 PHP
PHP 数组排序方法总结 推荐收藏
2010/06/30 PHP
关于PHP求解三数之和问题详析
2020/11/09 PHP
再谈javascript图片预加载技术(详细演示)
2011/03/12 Javascript
JavaScript高级程序设计(第3版)学习笔记9 js函数(下)
2012/10/11 Javascript
js计算任意值之间随机数的方法
2015/01/16 Javascript
jQuery prototype冲突的2种解决方法(附demo示例下载)
2016/01/21 Javascript
详解JavaScript for循环中发送AJAX请求问题
2020/06/23 Javascript
JQueryEasyUI框架下的combobox的取值和绑定的方法
2017/01/22 Javascript
js时间戳格式化成日期格式的多种方法介绍
2017/02/16 Javascript
vue-video-player 通过自定义按钮组件实现全屏切换效果【推荐】
2018/08/29 Javascript
对layui初始化列表的CheckBox属性详解
2019/09/13 Javascript
JavaScript面向对象核心知识与概念归纳整理
2020/05/09 Javascript
NodeJS多种创建WebSocket监听的方式(三种)
2020/06/04 NodeJs
vue tab切换,解决echartst图表宽度只有100px的问题
2020/07/19 Javascript
[07:37]DOTA2-DPC中国联赛2月2日Recap集锦
2021/03/11 DOTA
Python写的英文字符大小写转换代码示例
2015/03/06 Python
在python中使用xlrd获取合并单元格的方法
2018/12/26 Python
基于wxPython的GUI实现输入对话框(1)
2019/02/27 Python
python使用PyQt5的简单方法
2019/02/27 Python
简单的Python调度器Schedule详解
2019/08/30 Python
Django Admin中增加导出CSV功能过程解析
2019/09/04 Python
Python Flask上下文管理机制实例解析
2020/03/16 Python
纯CSS3打造属于自己的“小黄人”
2016/03/14 HTML / CSS
巧克力领导品牌瑞士莲美国官网:Lindt Chocolate美国
2016/08/25 全球购物
新加坡最佳婴儿用品店:Mamahood.com.sg
2018/08/26 全球购物
美国眼镜在线零售商:Dualens
2019/12/07 全球购物
东方红海科技面试题软件测试方面
2012/02/08 面试题
2013届毕业生求职信范文
2013/11/20 职场文书
蟋蟀的住宅教学反思
2014/04/26 职场文书
企业文化标语大全
2014/06/10 职场文书
追悼会悼词大全
2015/06/23 职场文书
2015年秋季小学开学典礼主持词
2015/07/16 职场文书
2016大学生优秀志愿者事迹材料
2016/02/25 职场文书
python 通过使用Yolact训练数据集
2021/04/06 Python
ORACLE查看当前账号的相关信息
2021/06/18 Oracle