while i <= 8:
s += name[i]
i += 1
print(s)
因为这样的循环在 Python 中非常常用,所以被封装成为了一种简便的方法,就是字符串的 切片。切片的基本格式和使用方法如下:
name = “meet_alex_wusir”
0123456789
print(name[5:9]) # [起始位置:终止位置] 顾头不顾腚(起始位置保留,终止位置不保留)
print(name[-5:]) # [起始位置:终止位置(默认到结尾)] 顾头不顾腚
print(name[:]) # [起始位置(默认从开头):终止位置(默认到结尾)] 顾头不顾腚
输出的结果为:
alex
wusir
meet_alex_wusir
关于切片的终止位置的选择,还有一个技巧是:终止位置 = 起始位置 + 切片长度。例如上面的例子中,起始位置为 5,切片长度为 4,终止位置为 5 + 4 = 9。
有的时候我们并不想要一个一个取字符,而是要隔一个字符取一个。比如对于上面 “meet_alex_wusir” 的例子,我们想要取第 3、5、7 位的 e、_、l,该如何操作呢?
我们依旧可以使用最原始的,分别取值,然后拼接字符串的方法:
‘’’
Python学习交流,免费公开课,免费资料,
免费答疑,系统学习加QQ群:579817333
‘’’
name = “meet_alex_wusir”
a = name[2]
b = name[4]
c = name[6]
print(a + b + c)
这种方法确实能得到我们想要的结果,但是太过繁琐。如果我们想要处理很长的字符串,就会非常麻烦了。这就需要我们在切片时引入 步长 变量。步长 是使用切片方法的第三个参数,默认值为 1。对于上面的例子,我们可以设置 步长 为 2:
name = “meet_alex_wusir”
#0123456789
#-6-5-4-3-2-1
print(name[2:7:2]) #[起始位置:终止位置:步长(默认为1)]
如果我们把步长设置成 -1,可以实现从右向左查找:
name = “meet_alex_wusir”
print(name[-1:3:-1]) # 步长可以控制查找方向
输出的结果为:
risuw_xela_
在进行索引操作时,如果输入的参数超过最大索引值时,程序会报错。而在进行切片操作时,如果终止位置超出最大索引值时,程序不会报错,而是会走到字符串的结尾:
name = “meet_alex_wusir”
print(name[2:20:2])
输出的结果为:
e_lxwsr
在进行索引操作时,如果输入的参数超过最大索引值时,程序会报错。而在进行切片操作时,如果终止位置超出最大索引值时,程序不会报错,而是会走到字符串的结尾:
name = “meet_alex_wusir”
print(name[2:20:2])
输出的结果为:
e_lxwsr
需要注意的是,索引和切片只能给有序数据(字符串、列表、元组)使用。整型和布尔值等均不可以用来进行索引和切片操作。
同整型一样,字符串也是一个不可变的数据类型:
‘’’
Python学习交流,免费公开课,免费资料,
免费答疑,系统学习加QQ群:579817333
‘’’
name = “meet”
print(id(name)) # 2388909933712
name = name + “最帅了”
print(id(name)) # 2388910157296
在 Python 中,对于字符串的赋值,还会有这样一个有趣的情况:
name = “meet”
name1 = “meet”
print(id(name)) # 2313349022864