a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
为方便总结,我们来分小类型举例切片的应用。
4.1. 切片表达式中仅有一对冒号情形
【提示】这种情况下,暗含着一个前提是:步长值step取值为1,因此切片方向遵循“自左向右”切的原则。
a
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
4.1.1 最简单情形
a[2:6]
[2, 3, 4, 5]
a[2:9]
[2, 3, 4, 5, 6, 7, 8]
【提示】在此两例中,符合“左闭右开”原则,故最后切片结果集中去掉最后一个下标元素。
4.1.2 切片截止索引位置“超界”
根据上面切片规则7的说明,切片操作时索引不存在真正“越界”问题。请结合切片规则7看下面的举例。
a[2:10]
[2, 3, 4, 5, 6, 7, 8, 9]
【解析】根据“左闭右开”原则,切片结果集将包含a[2],a[3]……直到a[9]的8个元素。
a[2:20]
[2, 3, 4, 5, 6, 7, 8, 9]
【解析】根据切片规则7,a[2:20]等价于a[2:10](10=len(a),即列表最右边)。下面两个例子理由同这两个例子:
a[-3:10]
[7, 8, 9]
a[-3:20]
[7, 8, 9]
4.1.3 切片的起始索引位置超界
a[-10:-8]
[0, 1]
a[-100:-8]
[0, 1]
a[-100:2]<