Сравнение элементов в списке списков

У меня в основном есть список списков, как это: [['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')]

2 ответа

Решение

Поскольку ваш вопрос немного неясен, попробуйте это и проверьте, нормально это или нет.

bad_list = []
f=''
for i,s in enumerate(l):
    if s[0] == l[i-1][0] or s[0] in bad_list:
        f = f + ' '.join(s[1:])
        bad_list.append(s[0])           
    else:
        f = f + ' '.join(s)
    f = f+ ' ;'
f = [f[:-1] + '.']

f будет вашим ожидаемым результатом.

Если вы ищете для группировки списков на основе первого элемента, вы можете легко сделать это, используя defaultdict

>>> from collections import defaultdict
>>> triples =  [['sd', 'pd', 'od'], ['sd', 'pd1', 'od2'], ['sd2', 'pd2', 'od']]
>>> d = defaultdict(list)
>>> 
>>> for k,*l in triples:
...     d[k].extend(l)
...
>>> res = [[k]+l for k,l in d.items()]
>>> print(res)
[['sd', 'pd', 'od', 'pd1', 'od2'], ['sd2', 'pd2', 'od']]
Другие вопросы по тегам