一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析

Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析

2020-06-22 10:25wztshine Python

這篇文章主要介紹了Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

用法:注意是用英文的逗號(hào)",",且之間沒(méi)有空格。

文件名,[工作表名稱,不寫則默認(rèn)當(dāng)前激活的表],[從第幾行開(kāi)始,不寫則默認(rèn)第二行,因?yàn)楹芏啾淼谝恍惺莟itle],列名(第一列是要查找的元素,列名可以不連續(xù),比如“ade”)

腳本會(huì)自動(dòng)把要查找的第一列進(jìn)行大小寫變換,去除空格等操作,下面的例子中,第一列的名字有的是大寫,有的小寫,前后還有空格,腳本會(huì)默認(rèn)它們相同

現(xiàn)有Sheet1,內(nèi)容如下

Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析

Sheet2內(nèi)容如下

Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析

想把 Sheet1 的 B,C 列的信息復(fù)制到 Sheet2 的 B,C列上,執(zhí)行腳本:

?
1
2
3
4
5
6
7
8
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的內(nèi)容就變成了:

Python Excel vlookup函數(shù)實(shí)現(xiàn)過(guò)程解析

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
import openpyxl
 
def read_Excel(path,sheetName,row,*col):
  # 默認(rèn)從第二行開(kāi)始,因?yàn)楹芏啾矶加斜眍^
  if row == '':
    row = 2
  else:
    row = int(row)
  workbook = openpyxl.load_workbook(path)
  # 默認(rèn)打開(kāi)當(dāng)前激活的工作表
  if sheetName == "":
    sheet0 = workbook.active # 獲取當(dāng)前激活的工作表
  else:
    sheet0 = workbook[sheetName] # 如果制定了工作表,就打開(kāi)指定的工作表
  highest = sheet0.max_row
  case_list = {}
  # title 所在列,對(duì)比的那一列,假設(shè)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):
  # 將處理好的數(shù)據(jù)再次寫入excel
  if row == "":
    row = 2
  else:
    row = int(row)
  workbook = openpyxl.load_workbook(path)
  if sheetName == "":
    sheet0 = workbook.active # 獲取當(dāng)前激活的工作表
  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):
  # 對(duì)比處理兩次讀取的內(nèi)容,然后更新r2的內(nèi)容
  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])):
          # 如果想要不想覆蓋原有的數(shù)值,可以取消注釋,然后刪除下面那行
          # 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()

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://www.cnblogs.com/wztshine/p/13168235.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本老妇和子乱视频 | 亚洲欧美日韩中文字幕久久 | 30分钟的高清视频在线观看 | 激情男人天堂 | 色婷婷婷丁香亚洲综合不卡 | 人体做爰aaaa免费 | 日本不卡免费新一二三区 | 边摸边操 | 免费观看小视频 | 久久免费黄色 | 我的妹妹最近有点怪在线观看 | 国产精品一区二区在线观看完整版 | 我和老丈洗澡同性 | 三级黄色片在线免费观看 | 日本mv精品中文字幕 | 亚洲精品视频在线 | 美女扒开两腿露出尿口的视频 | 爱情岛论坛亚洲品质自拍视频 | 色悠久久久 | 人成网站在线观看 | 日本不卡不码高清免费观看 | youjizzxxx69日本 | 免费国产影视观看网站入口 | 好大好爽好舒服视频 | 国产美女屁股直流白浆视频无遮挡 | 午夜国产精品视频在线 | 精品欧美日韩一区二区三区 | 亚洲欧美激情日韩在线 | 被高跟鞋调教丨vk | 亚洲精品久久玖玖玖玖 | 精灵之森高清在线 | 国产永久一区二区三区 | 午夜精品国产 | 羞羞色男人的天堂伊人久久 | 国产aaa伦理片 | 天天曰| www免费插插视频 | 欧美日韩国产在线人成dvd | 五月天精品视频在线观看 | 四虎网站在线 | 91大神在线观看精品一区 |