Python的字符串切片及常用方法

Python08

Python的字符串切片及常用方法,第1张

获取Python字符串中的某字符可以使用索引

截取字符串中的一段字符串可以使用切片,切片在方括号中使用冒号:来分隔需要截取的首尾字符串的索引,方式是包括开头,不包括结尾

当尾索引没有给出时,默认截取到字符串的末尾

当头索引没有给出的时候默认从字符串开头开始截取

当尾索引和头索引都没有给出的时候,默认返回整个字符串,不过这只是一个浅拷贝

当尾索引大于总的字符串长度时,默认只截取到字符串末尾,很明显使用这种方法来截取一段到字符串末尾的子字符串是非常不明智的,应该是不给出尾索引才是最佳实践

当头索引为负数时,则是指从字符串的尾部开始计数,最末尾的字符记为-1,以此类推,因此此时应该注意尾索引的值,尾索引同样可以为负数,如果尾索引的值指明的字符串位置小于或等于头索引,此时返回的就是空字符串

切片是Python中截取字符串最强大的功能。

以下列举部分Python字符串常用的方法:

取一个list的部分元素是非常常见的操作。比如,一个list如下:

>>>L = ['Adam', 'Lisa', 'Bart', 'Paul']

取前3个元素,应该怎么做?

对这种经常取指定索引范围的操作,用循环十分繁琐,因此,Python提供了切片(Slice)操作符,能大大简化这种操作。

对应上面的问题,取前3个元素,用一行代码就可以完成切片:

>>>L[0:3]

['Adam', 'Lisa', 'Bart']

L[0:3]表示,从索引0开始取,直到索引3为止,但不包括索引3。即索引0,1,2,正好是3个元素。

只用一个 : ,表示从头到尾:

>>>L[:]

['Adam', 'Lisa', 'Bart', 'Paul']

因此,L[:]实际上复制出了一个新list。

切片操作还可以指定第三个参数:

>>>L[::2]

['Adam', 'Bart']

第三个参数表示每N个取一个,上面的 L[::2] 会每两个元素取出一个来,也就是隔一个取一个。

把list换成tuple,切片操作完全相同,只是切片的结果也变成了tuple。

"""

其中,第一个数字start表示切片开始位置,默认为0;

第二个数字end表示切片截止(但不包含)位置(默认为列表长度);

第三个数字step表示切片的步长(默认为1)。

当start为0时可以省略,当end为列表长度时可以省略,

当step为1时可以省略,并且省略步长时可以同时省略最后一个冒号。

另外,当step为负整数时,表示反向切片,这时start应该比end的值要大才行。

"""

aList = [3, 4, 5, 6, 7, 9, 11, 13, 15, 17]

print (aList[::]) # 返回包含原列表中所有元素的新列表

print (aList[::-1]) # 返回包含原列表中所有元素的逆序列表

print (aList[::2]) # 隔一个取一个,获取偶数位置的元素

print (aList[1::2]) # 隔一个取一个,获取奇数位置的元素

print (aList[3:6]) # 指定切片的开始和结束位置

aList[0:100] # 切片结束位置大于列表长度时,从列表尾部截断

aList[100:] # 切片开始位置大于列表长度时,返回空列表

aList[len(aList):] = [9] # 在列表尾部增加元素

aList[:0] = [1, 2] # 在列表头部插入元素

aList[3:3] = [4] # 在列表中间位置插入元素

aList[:3] = [1, 2] # 替换列表元素,等号两边的列表长度相等

aList[3:] = [4, 5, 6] # 等号两边的列表长度也可以不相等

aList[::2] = [0] * 3 # 隔一个修改一个

print (aList)

aList[::2] = ['a', 'b', 'c'] # 隔一个修改一个

aList[::2] = [1,2] # 左侧切片不连续,等号两边列表长度必须相等

aList[:3] = [] # 删除列表中前3个元素

del aList[:3] # 切片元素连续

del aList[::2] # 切片元素不连续,隔一个删一个