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' 方法来迭代该列表。

  • 初始化值附加到空字典中。

  • 这在控制台上显示为输出。