我基本上有一个这样的列表列表:
[['sd', 'pd', 'od'], ['sd', 'pd1', 'od2'], ['sd2', 'pd2', 'od']]
我希望输出是['sd pd od ; pd1 od2 .', 'sd2 pd2 od .']
所以,我想比较每个列表的第一个元素,如果它们相同,我想省略第一个元素(发生在第二个列表中)。
这是我的代码,它不起作用,因为它比较元素太多,我不知道为什么。
def simplistic(triples):
base = []
for x in triples:
for y in triples:
if x[0] == y[0]:
base.append((x[:],y[1],y[2]))
print(base)
这段代码的输出是:
[(['sd', 'pd', 'od'], 'pd', 'od'), (['sd', 'pd', 'od'], 'pd1', 'od2'), (['sd', 'pd1', 'od2'], 'pd', 'od'), (['sd', 'pd1', 'od2'], 'pd1', 'od2'), (['sd2', 'pd2', 'od'], 'pd2', 'od')]