实现你想要的最简单的方法是“按字面意思写”:for value in dictionary.values():
del value[2:]
可以理解为:for every value in the dictionary, remove all elements after the
second.
请注意:此解决方案不会创建新字典,而是在适当位置修改原始字典
此解决方案不会创建新列表。它会就地修改当前列表。在
在某些情况下,您可能希望创建一个新字典和/或避免改变字典的值,在这种情况下,您应该避免使用del,而是重新分配切片的值:
^{pr2}$
它似乎也是最有效的:In [1]: %%timeit
...: a = {'A': [1,2,3,4,5], 'B': [1,2]}
...: for value in a.values():
...: del value[2:]
...:
1000000 loops, best of 3: 663 ns per loop
In [2]: %%timeit
...: a = {'A': [1,2,3,4,5], 'B': [1,2]}
...: for key, value in a.items():
...: a[key] = value[:2]
...:
1000000 loops, best of 3: 920 ns per loop
In [3]: %%timeit
...: a = {'A': [1,2,3,4,5], 'B': [1,2]}
...: for value in a.values():
...: if len(value) > 2:
...: del value[2:]
...:
1000000 loops, best of 3: 796 ns per loop
In [4]: %%timeit
...: a = {'A': [1,2,3,4,5], 'B': [1,2]}
...: a = {k:v[:2] for k,v in a.items()}
...:
1000000 loops, best of 3: 1.15 us per loop
如果大多数值的长度为2或更短,则仅在必要时向切片添加if len(value) > 2:可能会使性能略有提高。
如果您希望大多数值大于2,那么它只会增加开销。在
关于你的第一个问题:
做del a["A"][3:len(a[2])]不会得到[3, 4, [1, 2, 3]]作为输出。
你得到一个KeyError: 2。如果您获得了那个输出,那么您已经做了其他事情。在