Python 切片中的算术,结束行为



我想以特定的切片排列遍历列表:

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

相关内容

最新更新