Python 平均切割字符串

Python015

Python 平均切割字符串,第1张

def cut_text(text, lenth): # lenth 表示切割的子字符串的长度

    import re

    textArr = re.findall('.{'+str(lenth)+'}', text)

    textArr.append(text[(len(textArr)*lenth):])

    if textArr[-1] =='': textArr.pop()

    return textArr

示例:

结果:

['ABCA', 'ABCA', 'ABCA', 'ABCA', 'ABCA']

val[0:-1]是python特有的切片操作,也叫切割操作,这里的下标0表示左起第一个元素, -1表示倒数最后一个元素。

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

“L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack']”

取前3个元素,利用切片操作就是“L[0:3]”。如果第一个索引是0,还可以省略“L[:3]”。

也可以从索引1开始,取出2个元素出来,L[1:3],显示的结果就是“['Sarah', 'Tracy']”。

类似的,既然Python支持L[-1]取倒数第一个元素,那么它同样支持倒数切片,试试“L[-2:]”,返回的就是“['Bob', 'Jack']”,记住倒数第一个元素的索引是-1。

扩展资料:

对于具有序列结构的数据来说,切片操作的方法是:consequence[start_index: end_index: step]。

1、start_index:表示是第一个元素对象,正索引位置默认为0;负索引位置默认为 -len(consequence)

2、end_index:表示是最后一个元素对象,正索引位置默认为 len(consequence)-1;负索引位置默认为 -1。

3、step:表示取值的步长,默认为1,步长值不能为0。

注意:对于序列结构数据来说,索引和步长都具有正负两个值,分别表示左右两个方向取值。索引的正方向从左往右取值,起始位置为0;负方向从右往左取值,起始位置为-1。因此任意一个序列结构数据的索引范围为 -len(consequence) 到 len(consequence)-1 范围内的连续整数。

切片操作会将按照给定的索引和步长,截取序列中由连续的对象组成的片段,单个索引返回值可以视为只含有一个对象的连续片段。

切片的过程是从第一个想要的对象开始,到第一个不想要的对象结束。第一个想要的对象到第一个不想要的对象之间的连续对象就是你所有想要的对象。

因此在consequence[start_index: end_index]中,切片中包含了consequence[start_index],但不包括consequence[end_index]。

参考资料来源:百度百科——python