Trzeba będzie konwertować list do listy krotek, a następnie użyj skrzyżowanie. Zauważ, że poniższe rozwiązanie może zawierać elementy w innej kolejności, a duplikaty oczywiście nie będą dostępne, ponieważ używam zestawu.
In [1]: l1 = [[1, 2], [4], [5, 6, 2], [1, 2], [3], [4], [5,9]]
In [2]: l2 = [[1, 2], [4], [5, 6, 2], [1, 2], [3], [4], [5,6], [1,2]]
In [3]: [list(x) for x in set(tuple(x) for x in l1).intersection(set(tuple(x) for x in l2))]
Out[3]: [[1, 2], [5, 6, 2], [3], [4]]
alternatywnie można zapisać skrzyżowanie w zmiennej i uzyskać ostateczną listę, jeśli zamówienie, duplikaty są konieczne:
In [4]: intersection = set(tuple(x) for x in l1).intersection(set(tuple(x) for x in l2))
In [5]: [x for x in l1 if tuple(x) in intersection]
Out[5]: [[1, 2], [4], [5, 6, 2], [1, 2], [3], [4]]
A skrzyżowanie, na wszelki wypadek, jeśli jesteś zainteresowany.
In [6]: print intersection
set([(1, 2), (5, 6, 2), (3,), (4,)])
Będzie to działać całkiem dobrze dla dużych list, ale wówczas, gdy listy są małe, należy zbadać inne rozwiązania w drodze @timegb (którego rozwiązanie będzie bardzo unoptimal dłuższych list)
problem I stwierdzono, że niezdolność do przekształcania listę list do zestawu, jeśli to było możliwe, to skrzyżowanie może być podjęta łatwo –
proszę wyjaśnić logikę, według której uzyskano dane wyjściowe. – timgeb
Czy możesz wyjaśnić, dlaczego '[5, 6]' i '[5, 9]' znajdują się na skrzyżowaniu? – NiziL