簡體   English   中英

比較嵌套字典中的多個鍵

[英]Comparing multiple keys in a nested dictionary

假設我有以下嵌套字典:

{Cow:{legs:thick, tail:long, milk:good, meat:alright}, Goat:{legs:slender, tail:short, milk:ok, meat:excellent}, Fish:{fins:yes, meat:superb, bones:plenty}}

我的目標是比較外鍵(牛,山羊和魚),並檢查它們的內鍵是否匹配。 理想情況下,我應該得到:

Cow legs: thick 
Goat legs: slender

Cow tail: long
Goat tail: short

Cow milk: good 
Goat milk: ok

Cow meat: alright
Goat meat: excelent
Fish meat: superb

Fish fins: yes
Fish bones: plenty

對我來說,問題是我還無法弄清楚如何比較多個詞典中的內鍵。

我可以按照傳統方式打開嵌套字典的包裝:

for outerkeys, innerdicts in nestedDict:
      #but here I'm stuck on how to process multiple inner dictionaries
      #to extract matching (and unmatching) keys.

首先,您要按“類別”(例如“腿”,“尾巴”,“肉”)分組,這是內部詞典的關鍵。

然后您可以迭代新詞典並以所需格式列出輸出:

from collections import defaultdict

in_dic = {"Cow": {"legs": "thick", "tail": "long", "milk": "good", "meat": "alright"},
          "Goat": {"legs": "slender", "tail": "short", "milk": "ok", "meat": "excellent"},
          "Fish": {"fins": "yes", "meat": "superb", "bones": "plenty"}}


result_by_category = defaultdict(list)

for animal, categories in in_dic.items():
    for category, value in categories.items():
        result_by_category[category].append((animal, value))

for category, values in result_by_category.items():
    for animal, value in values:
        print('{} {}: {}'.format(animal, category, value))
    print('')

輸出是確切的:

牛腿:粗
山羊腿:纖細

牛尾巴:長
山羊尾巴:短

牛奶:好
山羊奶:可以

牛肉:好
山羊肉:極好
魚肉:精湛

魚鰭:是的

魚骨頭:充足

您可以通過使用理解力構建帶有重組鍵/值的列表來做到這一點:

animals = {"Cow": {"legs": "thick", "tail": "long", "milk": "good", "meat": "alright"},
          "Goat": {"legs": "slender", "tail": "short", "milk": "ok", "meat": "excellent"},
          "Fish": {"fins": "yes", "meat": "superb", "bones": "plenty"}}

triples   = [(trait,animal,value) for animal,traits in animals.items() for trait,value in traits.items()]

lineBreak = {min(triples)[0]}
for trait,animal,value in sorted(triples):
    if not(trait in lineBreak or lineBreak.add(trait)): print("")
    print(f"{animal} {trait}: {value}")

...

Fish bones: plenty

Fish fins: yes

Cow legs: thick
Goat legs: slender

Cow meat: alright
Fish meat: superb
Goat meat: excellent

Cow milk: good
Goat milk: ok

Cow tail: long
Goat tail: short

您也可以嘗試使用grouby

from itertools import groupby
from operator import itemgetter

nested_dict = {
    "Cow": {"legs": "thick", "tail": "long", "milk": "good", "meat": "alright"},
    "Goat": {"legs": "slender", "tail": "short", "milk": "ok", "meat": "excellent"},
    "Fish": {"fins": "yes", "meat": "superb", "bones": "plenty"},
}

refactored_items = (
    (k1, k2, v2) for k1, v1 in nested_dict.items() for k2, v2 in v1.items()
)
sorted_refactored_items = sorted(refactored_items, key=itemgetter(1))
for _, g in groupby(sorted_refactored_items, key=itemgetter(1)):
    print("\n".join(f"{a} {b}: {c}" for a, b, c in g))
    print("")

輸出:

Fish bones: plenty

Fish fins: yes

Cow legs: thick
Goat legs: slender

Cow meat: alright
Goat meat: excellent
Fish meat: superb

Cow milk: good
Goat milk: ok

Cow tail: long
Goat tail: short

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM