返回其值重复的键

时间:2018-11-12 00:36:20

标签: python dictionary for-loop counter

我有一个字典,其键的值是列表。每个列表可能都包含一些重复多次的值

{'VSS': ['A2', 'A3', 'A1'], 'X_P1_1': ['A2', 'A1'], 'X_P2': ['A3', 'A2'], 'X_P1_3': ['A2', 'A1'], 'VDD': ['A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'B', 'A3'], 'X': ['B', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'B', 'A1']}

我想做一个循环,以获取其值的频率大于1的键 例如:

VDD: ['A3':8]
X : ['A1':8, 'B':2]

这怎么办?

3 个答案:

答案 0 :(得分:2)

您可以使用Counter

from collections import Counter

data = {'VSS': ['A2', 'A3', 'A1'], 'X_P1_1': ['A2', 'A1'], 'X_P2': ['A3', 'A2'], 'X_P1_3': ['A2', 'A1'], 'VDD': ['A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'B', 'A3'], 'X': ['B', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'B', 'A1']}


result = {key : { e: count for e, count in Counter(values).items() if count > 1}  for key, values in data.items() if any(value > 1 for value in Counter(values).values())}

print(result)

输出

{'VDD': {'A3': 8}, 'X': {'B': 2, 'A1': 8}}

或者,如果您希望这些值作为元组列表:

from collections import Counter

data = {'VSS': ['A2', 'A3', 'A1'], 'X_P1_1': ['A2', 'A1'], 'X_P2': ['A3', 'A2'], 'X_P1_3': ['A2', 'A1'],
        'VDD': ['A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'A3', 'B', 'A3'],
        'X': ['B', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'A1', 'B', 'A1']}

result = {key: [(element, count) for element, count in counts.items() if count > 1] for key, counts in map(lambda x: (x[0], Counter(x[1])), data.items()) if
          any(count > 1 for count in counts.values())}
print(result)

输出

{'VDD': [('A3', 8)], 'X': [('A1', 8), ('B', 2)]}

答案 1 :(得分:1)

使用collections.Counter

from collections import Counter

# count values in lists, only including counts greater than 1
c = {k: {val: count for val, count in Counter(v).items() if count > 1} \
     for k, v in d.items()}

# isolate only keys where Counter value is non-empty
res = {k: v for k, v in c.items() if v}

{'VDD': {'A3': 8},
 'X': {'B': 2, 'A1': 8}}

答案 2 :(得分:0)

第一步是反转映射。

valuekeydict = {}
for k, vs in orig_dict.items():
    for v in vs:
        valuekeydict.setdefault(v, []).append(v)

然后获取一组所有值,其中len> 1

result = {v for vs in valuekeydict.values() for v in vs if len(vs) > 1}