索引
s = "hello world"
s[0]
s[1]
s[-2]
分片
分片用来从序列中提取出想要的子序列,其用法为:
var[lower:upper:step]
其范围包括 lower ,但不包括 upper ,即 [lower, upper), step 表示取值间隔大小,如果没有默认为1。
s = 'hello world'
s[1:3] #'el'
s[1:-2] #'ello wor' 包括1不包括-2
s[:3] #'hel' 省略lower,不包括3
s[3:] #'lo world' 省略upper,包括3
s[:]
s[::2] #'hlowrd'
s[::-2] #'drwolh' 当step的值为负时,省略lower意味着从结尾开始分片,
#省略upper意味着一直分片到开头。
使用0索引开头打原因
使用[low, up)形式的原因
假设需要表示字符串 hello 中的内部子串 el :
方式
[low, up)
(low, up]
(lower, upper)
[lower, upper]
表示
[1,3)
(0,2]
(0,3)
[1,2]
序列长度
up - low
up - low
up - low - 1
up - low + 1
对长度来说,前两种方式比较好,因为不需要烦人的加一减一。
现在只考虑前两种方法,假设要表示字符串hello中的从头开始的子串hel:
方式
[low, up)
(low, up]
表示
[0,3)
(-1,2]
序列长度
up - low
up - low
第二种表示方法从-1开始,不是很好,所以选择使用第一种[low, up)的形式。
使用0-base的形式
两种简单的情况:
从头开始的n个元素;
使用0-base:[0, n)
使用1-base:[1, n+1)
第i+1个元素到第i+n个元素。
使用0-base:[i, n+i)
使用1-base:[i+1, n+i+1)
1-base有个+1部分,所以不推荐。
综合这两种原因,Python使用0-base的方法来进行索引。