分片
分片用来从序列中提取出想要的子序列,其用法为:
var[lower:upper:step]
其范围包括 lower ,但不包括 upper ,即 [lower, upper)
, step 表示取值间隔大小,如果没有默认为1。
lower和upper可以省略,省略lower意味着从开头开始分片,省略upper意味着一直分片到结尾。
当step的值为负时,省略lower意味着从结尾开始分片,省略upper意味着一直分片到开头。
当给定的upper超出字符串的长度(注意:因为不包含upper,所以可以等于)时,Python并不会报错,不过只会计算到结尾。
使用“0”作为索引开头的原因
(图片转自https://lijin-thu.github.io)
与字符串不同的是,列表可以通过索引和分片来修改。
对于字符串,如果我们通过索引或者分片来修改,Python会报错
事实上,对于连续的分片(即步长为 1 ),Python采用的是整段替换的方法,两者的元素个数并不需要相同,例如,将 [11,12] 替换为 [1,2,3,4]
对于不连续(间隔step不为1)的片段进行修改时,两者的元素数目必须一致。
可变和不可变类型
原因:字符串与整数浮点数一样被认为是基本类型,而基本类型在Python中是不可变的。
即或者直接替换掉其中的某个字符会报错,仅调用方法是不能改变字符串的内容的,如果想改变需要重新赋值给字符串变量。
(图片转自https://lijin-thu.github.io)
测试程序执行时间
IPython专门提供了两个魔术函数(%time
和%timeit
)以便自动完成该过程。%time
一次执行一条语句,然后报告总体执行时间。
对相同语句多次执行%time
的话,就会发现其结果是会变的。为了得到更为精确的结果,需要使用魔术函数%timeit
。对于任意语句,它会自动多次执行以产生一个非常精确的平均执行时间。
元组的生成速度会比列表快很多,迭代速度快一点,索引速度差不多。
1,2行代码代表生成
3,4,5代表迭代
6,7代表所引