索引
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的方法来进行索引。
网友评论