我想以特定的切片排列遍历列表:
l = range(10)
for i in (0,1,2):
print l[i:i + 3]
# [0, 1, 2]
# [1, 2, 3]
# [2, 3, 4]
但是当我尝试从列表的末尾执行此操作时,i = 0
失败的情况
l = range(10)
for i in (0,1,2):
print l[-(i + 3):-i]
# [] // expected: [7, 8, 9]
# [6, 7, 8]
# [5, 6, 7]
我明白为什么这不起作用。
l[-1:]
l[-1:None]
两者都有效,但
l[-1:0]
由于0
引用第一个元素而不是"最后一个元素之后的元素"而检索空集。
但是,我想知道是否有一种解决方案可以实现简单的"从x到结束的迭代",其中end
不必特别处理,以防我真正到达终点。
上面的例子只是例子,我正在尝试在 NumPy 中分配值,所以l[...].reverse()
等将不起作用。
您可以使用
len(l) - i
代替-i
:
l = range(10)
for i in (0,1,2):
print l[-(i + 3):len(l) - i]
输出:
[7, 8, 9]
[6, 7, 8]
[5, 6, 7]
一种方法是做一些算术以避免使用负索引。
n = len(l)
for i in (0, 1, 2):
j = n - 3 - i;
print l[j: j + 3]
您还可以使用步骤运算符并反转列表:
for i in (0,1,2):
new_l = l[-1-i:-4-i:-1]
new_l.reverse()
print new_l