python实现excel函数_利用Python实现Excel的文件间的数据匹配功能

我们知道Excel有一个match函数,可以做数据匹配。

比如要根据人名获取成绩

blank.gif

而参考表sheet1的内容如下:

blank.gif

要根据sheet1匹配每人的成绩,用Excel是这么写

index(Sheet1!B:B,MATCH(A2,Sheet1!A:A,0))

意思就是获取sheet1的B列的内容,根据我的A列匹配sheet1的A列的内容

但是如何用python实现这一点呢,我写了一个函数,非常好用,分享给大家。

这个函数考虑到了匹配多个字段,多个sheet。

import pandas as pd

def match(file,sheetnames,reffile,refsheet,targetsegs,matchseg) #文件名 sheet列表 参考文件名 参考sheet 目标字段列表 参考字段

alldata=pd.read_excel(file,None)

refdata=pd.read_excel(reffile,refsheet)

#获取映射字典

maps={}

for i in refdata.index:

MatchSeg=refdata.loc[i,matchseg]

maps[MatchSeg]={}

for seg in targetsegs:

maps[MatchSeg][seg]=refdata.loc[i,seg]

#匹配数据

for sheet in sheetnames:

if(isinstance(sheet,int)):

sheet=list(alldata.keys())[sheet]

data=alldata[sheet].fillna('-')

for i in data.index:

MatchSeg=data.loc[i,matchseg]

for seg in targetsegs:

try:

data.loc[i,seg]=map[MatchSeg][seg]

except Exception as e:

pass

alldata[sheet]=data

#导出

with pd.ExcelWriter(file) as writer:

for sheet in alldata.keys():

alldata[sheet].to_excel(writer,sheet,index=False)

match('要匹配的表.xlsx',[0,1],'参考表.xlsx','参考页',['要匹配的字段1,字段2'],'参考字段')

总结

到此这篇关于利用Python实现Excel的文件间的数据匹配功能的文章就介绍到这了,更多相关Python实现Excel的文件间的数据匹配内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2020-06-14

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值