Python - 元素的分组连续范围索引
当需要获取列表中元素的分组连续索引范围时,会创建一个defaultdict。使用了一个简单的迭代,以及“groupby”方法、“len”方法、“list”方法和“append”方法。
示例
以下是相同的演示-
from itertools import groupby
from collections import defaultdict
my_list = [63, 12, 84, 91, 52, 39, 25, 27, 20, 11, 0,9]
print("名单是: " )
print(my_list)
my_index = 0
my_result = defaultdict(list)
for key, sub in groupby(my_list):
   element = len(list(sub))
   my_result[key].append((my_index, my_index + element - 1))
   my_index += element
print("结果字典是: ")
print(my_result)输出结果名单是:
[63, 12, 84, 91, 52, 39, 25, 27, 20, 11, 0, 9]
结果字典是:
defaultdict(, {63: [(0, 0)], 12: [(1, 1)], 84: [(2, 2)], 91: [(3, 3)], 52: [(4, 4)], 39: [(5, 5)], 25:
[(6, 6)], 27: [(7, 7)], 20: [(8, 8)], 11: [(9, 9)], 0: [(10, 10)], 9: [(11, 11)]})解释
所需的包被导入到环境中。
定义了一个整数列表并显示在控制台上。
一个值被初始化为0。
已创建默认字典。
通过在其上应用'groupby'方法来迭代该列表。
初始化值附加到空字典中。
这在控制台上显示为输出。
