我有一个字典,其键的值是列表。每个列表可能都包含一些重复多次的值
{'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]
这怎么办?
答案 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)
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}