我只有一个这样的词典列表:
[{'Y': 80, 'X': 70, 'C': 0, 'L': 'B'}, {'Y': 81, 'X': 71, 'C': 1, 'L': 'C'}, {'Y': 82, 'X': 72, 'C': 2, 'L': 'D'}, {'Y': 82, 'X': 72, 'C': 3, 'L': 'E'}, {'Y': 83, 'X': 73, 'C': 4, 'L': 'F'}]
分解后更容易阅读
{'Y': 80, 'X': 70, 'C': 0, 'L': 'B'}
{'Y': 81, 'X': 71, 'C': 1, 'L': 'C'}
{'Y': 82, 'X': 72, 'C': 2, 'L': 'D'}
{'Y': 82, 'X': 72, 'C': 3, 'L': 'E'}
{'Y': 83, 'X': 73, 'C': 4, 'L': 'F'}
,我想找到两个字典,其中“ Y”和“ X”相同。然后删除两个字典之一,并更新结果“ C”
{'Y': 80, 'X': 70, 'C': 0, 'L': 'B'}
{'Y': 81, 'X': 71, 'C': 1, 'L': 'C'}
{'Y': 82, 'X': 72, 'C': 2, 'L': 'D'}
{'Y': 83, 'X': 73, 'C': 3, 'L': 'F'}
答案 0 :(得分:1)
又快又脏:
d = [
{'Y': 80, 'X': 70, 'C': 0, 'L': 'B'},
{'Y': 81, 'X': 71, 'C': 1, 'L': 'C'},
{'Y': 82, 'X': 72, 'C': 2, 'L': 'D'},
{'Y': 82, 'X': 72, 'C': 3, 'L': 'E'},
{'Y': 83, 'X': 73, 'C': 4, 'L': 'F'}
]
Xs = []
Ys = []
c = 0
out = []
for i in range(len(d)):
obj = dict(d[i]) # Copy the dict at index i
if (obj["X"], obj["Y"]) in XYs:
XYs.append((obj["X"], obj["Y"]))
else:
obj["C"] = c
c = c + 1
out.append(obj)
XYs.append((obj["X"], obj["Y"]))
编辑:通过存储唯一的元组对其进行了改进