python3.9 处理excel来实现类似excel中的vlookup功能

#本次工作中需要处理两个excel中的数据,使用vlookup查询后显示N/A然后就选择了python#

python 复制代码
import openpyxl

# excel表格的绝对路径
path = r"C:\Users\Administrator\Desktop\device.xlsx"

# 打开表格对象
workbook = openpyxl.load_workbook(path) 

# 打印Excel表中的所有表 ,本次excel文件中就一个sheet1表
# print(workbook.sheetnames) 

# 选中sheet1 ==获取sheet1表格对象
sheet=workbook.active


# 取到第一列数据,是以这列数据为基准
src_data = sheet['A1:A206']


# 获取目标数据,上面取到的数据在这个目标数据区块中
des_data = sheet['C1:D206']

# 要填充的表格,获取要写入目标结果的列
tag_data = sheet['B1:B206']


# 定义一个字典来存取零时数据
data_dic = {}


# 因为目标数据块是两列,循环出来是每行数据有两列赋值到两个对象中
for sd in des_data:
    
    C,D = sd
    # print(C.value.split()[0],D.value)
    # 把循环出来的值添加到字典中,好让基准中的数据从字典中比较
    data_dic[C.value.split()[0]] = D.value.split()[0]


# 打印字典对象看看结果是不是和预想的一样
# print(data_dic)

# 测试数据,来看中间结果的
# for r in  src_data:
#     # d = r[0].value
#
#     # print(r[0].value,type(r[0].value))
#     if r[0].value in data_dic:
#         print(data_dic[r[0].value])
#


# 因为要取好几个地方的值,单独循环哪一个表格区域对象都不合适,所有采用下标的方式更加合适
for i in range(1,len(tag_data)):
    
    # 打印下看数组是不是所想要的
    print(src_data[i][0].value)
    
    # 取值进行比较
    if src_data[i][0].value in data_dic:
        
        # 如果字典中有这个键,就把对应这个键所对应的值写到新的表格对象中
        tag_data[i][0].value = data_dic[src_data[i][0].value]

# 保存数据到表格
 workbook.save(path)
相关推荐
七夜zippoe17 分钟前
可解释AI:构建可信的机器学习系统——反事实解释与概念激活实战
人工智能·python·机器学习·可解释性·概念激活
YuanDaima20483 小时前
[CrewAI] 第15课|构建一个多代理系统来实现自动化简历定制和面试准备
人工智能·python·面试·agent·crewai
WHS-_-20224 小时前
Python 算法题学习笔记一
python·学习·算法
码界筑梦坊4 小时前
353-基于Python的大湾区气候数据可视化分析系统
开发语言·python·信息可视化·数据分析·django·vue·毕业设计
如何原谅奋力过但无声4 小时前
【chap11-动态规划(上 - 基础题目&背包问题)】用Python3刷《代码随想录》
数据结构·python·算法·动态规划
云姜.5 小时前
JSON Schema使用
python·json
Sunshine for you5 小时前
使用Flask快速搭建轻量级Web应用
jvm·数据库·python
qwehjk20085 小时前
如何从Python初学者进阶为专家?
jvm·数据库·python
小熊Coding5 小时前
重庆市旅游景点数据可视化分析系统
爬虫·python·数据挖掘·数据分析·计算机毕业设计·数据可视化分析·旅游景点
sg_knight5 小时前
CentOS 裸机实操:5分钟完成 MinIO 单机部署与公网访问
linux·python·centos·文件管理·minio·ftp·oss