假設我們有一本字典inp = {"virat":60,"rohit":50,"sardhul":50,"rana":60},我們應該得到輸出{60: ['virat', 'rana'], 50: ['rohit', 'sardhul']}
我可以在正常的python編程中做到這一點,如下所示
out = dict()
for key, val in inp.items():
if val not in out:
out[val] = [key]
else:
out[val].append(key)
輸出是 {60: ['virat', 'rana'], 50: ['rohit', 'sardhul']}
我們如何在字典理解中做同樣的事情?
uj5u.com熱心網友回復:
一種更復雜的方法:
out = {}
for key, val in inp.items():
out.setdefault(val, []).append(key)
uj5u.com熱心網友回復:
正如其他人所提到的,它效率不高,但如果你必須有一個理解:
{ val: [ key for key,vv in inp.items() if vv == val ] for val in inp.values() }
這基本上相當于:
out = dict()
for val in inp.value():
tmp = list()
for key,vv in inp.items():
if vv == val:
tmp.append(key)
out[val] = tmp
...這比您的原始代碼效率低得多。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/414399.html
標籤:
上一篇:掃描儀方法.hasNextInt()和if陳述句-僅作業1次。對于下一個回圈-自動(不等待任何輸入)給出false
下一篇:如何根據串列中的新行拆分串列
