Сравнение списков в питоне - PullRequest
       12

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

2 голосов
/ 11 февраля 2011

У меня есть несколько списков.Мне нужно найти способ создать список уникальных элементов в каждом списке по сравнению со всеми списками.Есть ли простой или прямой способ сделать это?Я знаю, что эти списки могут в основном использоваться как set s.

Ответы [ 5 ]

5 голосов
/ 11 февраля 2011
import collections

def uniques(*args):
    """For an arbitrary number of sequences,
           return the items in each sequence which
            do not occur in any of the other sequences
    """

    # ensure that each value only occurs once in each sequence
    args = [set(a) for a in args]

    seen = collections.defaultdict(int)
    for a in args:
        for i in a:
            seen[i] += 1
    # seen[i] = number of sequences in which value i occurs

    # for each sequence, return items
    #  which only occur in one sequence (ie this one)
    return [[i for i in a if seen[i]==1] for a in args]

так

uniques([1,1,2,3,5], [2,3,4,5], [3,3,3,9])  ->  [[1], [4], [9]]
4 голосов
/ 11 февраля 2011

Используйте класс набора и операции набора, определенные в нем:

>>> l1 = [1,2,3,4,5,5]
>>> l2 = [3,4,4,6,7]
>>> set(l1) ^ set(l2)    # symmetric difference
set([1, 2, 5, 6, 7])

edit : Ах, вы неправильно прочитали ваш вопрос.Если вы имели в виду «уникальные элементы в l1, которых нет ни в одном из l2, l3, ..., ln, то:

l1set = set(l1)
for L in list_of_lists:   # list_of_lists = [l2, l3, ..., ln]
    l1set = l1set - set(L)
1 голос
/ 11 февраля 2011
l1 = [4, 6, 3, 7]
l2 = [5, 5, 3, 1]
l3 = [2, 5, 4, 3]
l4 = [9, 8, 7, 6]

# first find the union of the "other" lists
l_union = reduce(set.union, (map(set, (l1, l2, l3))))

# then subtract the union from the remaining list
uniques = set(l4) - l_union

print uniques

и результат:

>>> set([8, 9])
0 голосов
/ 11 февраля 2011
import itertools

# Test set
lists = []
lists.append([1,2,3,4,5,5])
lists.append([3,4,4,6,7])
lists.append([7,])
lists.append([8,9])
lists.append([10,10])

# Join all the lists removing the duplicates in each list
join_lists = []
for list_ in lists:
    join_lists.extend(set(list_))

# First, sort
join_lists.sort()

# Then, list only the groups with one element
print [ key for key, grp in itertools.groupby(join_lists) if len(list(grp)) < 2 ]

#>>> [1, 2, 6, 8, 9]

###
0 голосов
/ 11 февраля 2011
for l in lists:
  s = set(l)
  for o in lists:
    if o != l:
      s -= set(o)

  # At this point, s holds the items unique to l

Для эффективности вы можете преобразовать все списки в наборы один раз.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...