목록에 있는 요소의 그룹화된 연속 범위 인덱스를 가져와야 하는 경우 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("The list is : " ) 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("The resultant dictionary is : ") print(my_result)
출력
The list is : [63, 12, 84, 91, 52, 39, 25, 27, 20, 11, 0, 9] The resultant dictionary is : 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' 방법을 적용하여 반복됩니다.
-
초기화된 값은 빈 사전에 추가됩니다.
-
이것은 콘솔에 출력으로 표시됩니다.