>> it = [1, 2, 3, 4, 5, 6, 7, 8, 9] 我可以把它变成一个列表,然后在任意点切掉末端,例如 >>> it[1:-2] [2, 3, 4-6ren">
gpt4 book ai didi

python - Python 的切片边界和 "stride"之间的神秘交互

转载 作者:太空狗 更新时间:2023-10-29 17:17:13 28 4
gpt4 key购买 nike

我理解给定一个可迭代对象,例如

>>> it = [1, 2, 3, 4, 5, 6, 7, 8, 9]

我可以把它变成一个列表,然后在任意点切掉末端,例如

>>> it[1:-2]
[2, 3, 4, 5, 6, 7]

或反转

>>> it[::-1]
[9, 8, 7, 6, 5, 4, 3, 2, 1]

或将两者结合

>>> it[1:-2][::-1]
[7, 6, 5, 4, 3, 2]

但是,尝试在单个操作中完成此操作会产生一些令我困惑的结果:

>>> it[1:-2:-1] 
[]
>>>> it[-1:2:-1]
[9, 8, 7, 6, 5, 4]
>>>> it[-2:1:-1]
[8, 7, 6, 5, 4, 3]

只有经过反复试验,我才能得到我要找的东西:

>>> it[-3:0:-1]
[7, 6, 5, 4, 3, 2]

这让我很头疼(并且无法帮助阅读我的代码的读者):

>>> it[-3:0:-1] == it[1:-2][::-1]
True

我怎样才能理解这一点?我什至应该考虑这些事情吗?


FWYW,我的代码做了很多可迭代对象的截断、反转和列表化,我一直在寻找比 list(reversed(it[1 :-2]))

最佳答案

这是因为在像这样的切片中 -

list[start:stop:step]

start包含,结果列表从索引 start 开始。

stop排他性,即结果列表只包含 stop - 1 之前的元素(而不是stop 处的元素)。

因此对于您的情况it[1:-2] - 1包含 ,这意味着切片结果从索引 1 ,而 -2exclusive ,因此切片索引的最后一个元素将来自索引 -3 .

因此,如果您想要相反的情况,您必须执行 it[-3:0:-1] - 只有这样 -3 才会被包含在切片结果中,切片结果将上升到 1 索引。

关于python - Python 的切片边界和 "stride"之间的神秘交互,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33352169/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com