问题

如何判断一个list包含另一个list

例如我有两个list

List1 = ['a','c','c']
List2 = ['x','b','a','x','c','y','c']

如何判断list2包含了list1

解决方案

如果元素的数量不重要,也就是说只判断list1里的所有种类在list2都有出现过,那么使用set()即可

>>> List1 = ['a','c','c']
>>> List2 = ['x','b','a','x','c','y','c']
>>> set(List1) < set(List2)
True

如果元素的数量也需要考虑,即list1里的元素必须全部在list2里出现并且不重复,那么可以考虑使用Counter

from collections import Counter

def counterSubset(list1, list2):
    counter1 = Counter(list1)
    counter2 = Counter(list2)
    for k, v in counter1.items():
        if v > counter2[k]:
            return False
    return True

List1 = ['a', 'c', 'c']
List2 = ['x', 'b', 'a', 'x', 'c', 'y', 'c']
print(counterSubset(List1, List2))

我们还可以使用all()来简化代码

>>> from collections import Counter
>>> List1 = ['a', 'c', 'c']
>>> List2 = ['x', 'b', 'a', 'x', 'c', 'y', 'c']
>>> counter1 = Counter(List1)
>>> counter2 = Counter(List2)
>>> print(all(v <= counter2[k] for k, v in counter1.items()))
True

讨论

对于set类型,Python提供了一些操作符来描述两个集合的关系(包含、真包含等等)。而<操作符描述的是,一个集合是否是另一个集合的真子集

all()接受一个可迭代对象作为参数,并且判断这个可迭代对象的所有元素是否全部为True。相应的,还有any() 函数,用来判断是否存在一个True

来源

Stack Overflow

关注

欢迎关注我的微信公众号:python每日一练


python每日一练
351 声望754 粉丝