我正在尝试使用列表的原始索引作为键,从列表的每n个元素创建一个字典。因此,例如:
l = [1,2,3,4,5,6,7,8,9]
正在运行
dict(enumerate(l)).items()
给我:
dict_items([(0, 1), (1, 2), (2, 3), (3, 4), (4, 5), (5, 6), (6, 7), (7, 8), (8, 9)])
这就是我想要的。但是,当我现在想从l中选择第二个值来执行此操作时,问题就开始了,所以我尝试
dict(enumerate(l[::2])).items()
这给了我
dict_items([(0, 1), (1, 3), (2, 5), (3, 7), (4, 9)])
但是我不想要那样,我想在制作字典时保留原始索引。做这个的最好方式是什么?
我想要以下输出
dict_items([(0, 1), (2, 3), (4, 5), (6, 7), (8, 9)])
itertools.islice()
在enumerate()
对象上使用:
from itertools import islice
dict(islice(enumerate(l), None, None, 2)).items()
islice()
给你一个迭代器的一部分; 以上是第二个要素:
>>> from itertools import islice
>>> l = [1,2,3,4,5,6,7,8,9]
>>> dict(islice(enumerate(l), None, None, 2)).items()
dict_items([(0, 1), (8, 9), (2, 3), (4, 5), (6, 7)])
(请注意,输出是预期的,但顺序通常由哈希表确定)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句