python3.9 处理excel来实现类似excel中的vlookup功能
#���次工作中需要处理两个excel中的数据,使用vlookup查询后显示N/A然后就选择了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)()
The End