假設我有一個簡單的 Python 字典,如下所示:{'location1': [1], 'location2': [1], 'location3': [1], 'location4': [1], 'location5': [1]}我的目標是將這個字典分成一個字典列表,這些字典的大小都是特定的 N,除了最后一個字典的大小,如果字典中沒有足夠的元素,它可能小于 N。所以 N = 2 將產生:[{'location1': [1], 'location2': [1]}, {'location3': [1], 'location4': [1]}, {'location5': [1]}]當 N = 3 時會產生:[{'location1': [1], 'location2': [1], 'location3': [1]}, {'location4': [1]}, 'location5': [1]}]我已經嘗試過,但找不到方法來做到這一點。請注意,每個切片/批次中的位置對我來說并不重要,只要它們在切片之間均勻分布即可。
1 回答

MM們
TA貢獻1886條經驗 獲得超2個贊
嘗試這樣的事情:
n = 2 # the desired # of parts
items = list(d.items())
y = [dict(items[x:x+n+1]) for x in range(0, len(d), n+1)]
添加回答
舉報
0/150
提交
取消