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 相关文章推荐
利用Python脚本在Nginx和uwsgi上部署MoinMoin的教程
May 05 Python
详解Python的Django框架中的Cookie相关处理
Jul 22 Python
浅谈Python的文件类型
May 30 Python
Python3 模块、包调用&路径详解
Oct 25 Python
将tensorflow的ckpt模型存储为npy的实例
Jul 09 Python
Python全排列操作实例分析
Jul 24 Python
浅谈keras通过model.fit_generator训练模型(节省内存)
Jun 17 Python
浅谈PyTorch中in-place operation的含义
Jun 27 Python
python3.7添加dlib模块的方法
Jul 01 Python
Python装饰器结合递归原理解析
Jul 02 Python
python用Configobj模块读取配置文件
Sep 26 Python
python的变量和简单数字类型详解
Sep 15 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
DC动画很好看?新作烂得令人发指,名叫《红色之子》
2020/04/09 欧美动漫
php中使用Imagick实现图像直方图的实现代码
2011/08/30 PHP
php求数组全排列,元素所有组合的方法总结
2017/03/14 PHP
使用Codeigniter重写insert的方法(推荐)
2017/03/23 PHP
Yii2.0使用阿里云OSS的SDK上传图片、下载、删除图片示例
2017/09/20 PHP
Laravel中9个不经常用的小技巧汇总
2019/04/16 PHP
借用Google的Javascript API Loader来加速你的网站
2009/01/28 Javascript
COM中获取JavaScript数组大小的代码
2009/11/22 Javascript
判断一个变量是数组Array类型的方法
2013/09/16 Javascript
有趣的bootstrap走动进度条
2016/12/01 Javascript
基于JavaScript实现自定义滚动条
2017/01/25 Javascript
mockjs,json-server一起搭建前端通用的数据模拟框架教程
2017/12/18 Javascript
jQuery图片查看插件Magnify开发详解
2017/12/25 jQuery
vue axios整合使用全攻略
2018/05/24 Javascript
深入理解JS中Number(),parseInt(),parseFloat()三者比较
2018/08/24 Javascript
vue基础之v-bind属性、class和style用法分析
2019/03/11 Javascript
vue控制多行文字展开收起的实现示例
2019/10/11 Javascript
微信小程序工具函数封装
2019/10/28 Javascript
vue实现导航标题栏随页面滚动渐隐渐显效果
2020/03/12 Javascript
[01:28]国服启动器接入蒸汽平台操作流程视频
2021/03/11 DOTA
python中精确输出JSON浮点数的方法
2014/04/18 Python
python处理html转义字符的方法详解
2016/07/01 Python
利用python写个下载teahour音频的小脚本
2017/05/08 Python
python3.x上post发送json数据
2018/03/04 Python
属性与 @property 方法让你的python更高效
2020/09/21 Python
使用css3背景渐变中的透明度来设置不同颜色的背景渐变
2014/03/31 HTML / CSS
美国电力供应商店/电气批发商:USESI
2018/10/12 全球购物
365 Tickets英国:全球景点门票
2019/07/06 全球购物
学术会议主持词
2014/03/17 职场文书
英文自荐信常用句子
2014/03/26 职场文书
化工工艺设计求职信
2014/06/25 职场文书
三方股东合作协议书范本
2014/09/28 职场文书
麦田里的守望者读书笔记
2015/06/30 职场文书
2016元旦晚会主持词
2015/07/01 职场文书
给校长的建议书范文
2015/09/14 职场文书
SpringDataJPA在Entity中常用的注解介绍
2021/12/06 Java/Android