假设我们有一个列表列表,其中每个子列表都有两个元素。每个子列表的一个元素在列表的许多其他主题中是相同的。我们需要创建一个最终列表,该列表将显示按通用元素分组的子列表。
在给定列表中,第一个元素是字符串,第二个元素是数字。因此,我们创建了一个临时列表,其中将保存每个子列表的第二个元素。然后,我们将is子列表与temp列表中的每个元素进行比较,然后设计人员将它们分组。
listA = [['Mon', 2], ['Tue', 3], ['Wed', 3], ["Thu", 1], ['Fri', 2], ['Sat', 3], ['Sun', 1]] # With set and map temp = set(map(lambda i: i[1], listA)) res = [[j[0] for j in listA if j[1] == i] for i in temp] # Result print("The list with grouped elements is : \n" ,res)
输出结果
运行上面的代码给我们以下结果-
The list with grouped elements is : [['Thu', 'Sun'], ['Mon', 'Fri'], ['Tue', 'Wed', 'Sat']]
itemgetter函数用于获取每个子列表的第二个元素。然后根据itemgetter函数的结果对函数进行分组。
from itertools import groupby from operator import itemgetter listA = [['Mon', 2], ['Tue', 3], ['Wed', 3],["Thu", 1], ['Fri', 2], ['Sat', 3],['Sun', 1]] # With groupby listA.sort(key = itemgetter(1)) groups = groupby(listA, itemgetter(1)) res = [[i[0] for i in val] for (key, val) in groups] # Result print("The list with grouped elements is : \n" ,res)
输出结果
运行上面的代码给我们以下结果-
The list with grouped elements is : [['Thu', 'Sun'], ['Mon', 'Fri'], ['Tue', 'Wed', 'Sat']]
我们应用defaultdict函数来获取子列表的第二个元素作为字典的键。然后,在结果列表中,我们附加子列表的第一个元素的值。
import collections listA = [['Mon', 2], ['Tue', 3], ['Wed', 3],["Thu", 1], ['Fri', 2], ['Sat', 3],['Sun', 1]] # With defaultdict res = collections.defaultdict(list) for val in listA: res[val[1]].append(val[0]) # Result print("The list with grouped elements is : \n" ,res)
输出结果
运行上面的代码给我们以下结果-
The list with grouped elements is : defaultdict(<class 'list'>, {2: ['Mon', 'Fri'], 3: ['Tue', 'Wed', 'Sat'], 1: ['Thu', 'Sun']})