我有以下列表
a = ['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges']
以及以下列表列表
b = [['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges'], ['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges', 'Pear', 'Apple'], ['Oranges', 'Strawberry', 'Pear'], ... ]
如您所见,在b内部可以有
- 与a完全相同的列表
- 与a具有相同项目但顺序不同的列表
- 类似于 1 和 2 但比a更多的项目
- 类似于 1 和 2 但比a少的项目
- 与一个完全不同的列表
考虑到使用
for value in b:
print(value)
一个人能够获得b的每个列表,然后可以将其与a进行比较,如何知道案例 1、2 和 3 发生了多少次(包括重复)?
受到这个答案的启发,我进行了实验
count_matches = 0
for value in b:
ff = str(value).strip("[]")
gg = str(a).strip("[]")
if gg in ff:
count_matches += 1
print(count_matches)
但由于订单原因,这不起作用(例如,其他项目可能已添加到中间)。