-1

我有以下列表

a = ['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges']

以及以下列表列表

b = [['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges'], ['Bananas', 'Ananas', 'Peach', 'Grapes', 'Oranges', 'Pear', 'Apple'], ['Oranges', 'Strawberry', 'Pear'], ... ]

如您所见,在b内部可以有

  1. 与a完全相同的列表
  2. 与a具有相同项目但顺序不同的列表
  3. 类似于 1 和 2 但比a更多的项目
  4. 类似于 1 和 2 但比a少的项目
  5. 与一个完全不同的列表

考虑到使用

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)

但由于订单原因,这不起作用(例如,其他项目可能已添加到中间)。

4

1 回答 1

0

为了解决它,我将这种方法与 for 循环结合起来以获取值,如

count_matches = 0
for value in b:
    if set(a) <= set(value):
        count_matches += 1
        print("a is in b")  
于 2020-10-19T15:27:01.767 回答