字符串

一、下标

“下标” ⼜叫 “索引” ,就是编号。⽐如⽕⻋座位号,座位号的作⽤:按照编号快速找到对应的座位。同 理,下标的作⽤即是通过下标快速找到对应的数据。

1.数据在程序运行过程中存储在内存

2. 这些字符数据从0开始顺序分配一个编号 -- 使用这个编号精确找到某个字符数据 -- 下标或索引或索引值

 

具体操作如下: 

 

二.切片

切⽚是指对操作的对象截取其中⼀部分的操作。字符串、列表、元组都⽀持切⽚操作。

 2.1 语法

序列[开始位置下标:结束位置下标:步⻓]

注意:1. 不包含结束位置下标对应的数据, 正负整数均可;

           2. 步⻓是选取间隔,正负整数均可,默认步⻓为1。

2.2 体验切片

# 序列名[开始位置的下标:结束位置的下标:步长]

str1 = '012345678'

 print(str1[2:5:1]) # 234
 print(str1[2:5:2]) # 24
 print(str1[2:5]) # 234
print(str1[:5]) # 01234 -- 如果不写开始,默认从0开始选取
print(str1[2:]) # 2345678 -- 如果不写结束,表示选取到最后
print(str1[:]) # 012345678 -- 如果不写开始和结束,表示选取所有


print(str1[::-1]) # 876543210 -- 如果步长为负数,表示倒叙选取
 print(str1[-4:-1]) # 567 -- 下标-1表示最后一个数据,依次向前类推

 

 print(str1[-4:-1:1]) # 567
print(str1[-4:-1:-1]) # 不能选取出数据:从-4开始到-1结束,选取方向为从左到右,但是-1步长:从右向左选取
**** 如果选取方向(下标开始到结束的方向) 和 步长的方向冲突,则无法选取数据


print(str1[-1:-4:-1]) # 876

输出结果为:

三.常用操作方法

字符串的常⽤操作⽅法有查找、修改和判断三⼤类

3.1 查找

所谓字符串查找⽅法即是查找⼦串在字符串中的位置或出现的次数。

find():检测某个⼦串是否包含在这个字符串中,如果在返回这个⼦串开始的位置下标,否则则返 回-1。

1. 语法

字符串序列.find(⼦串, 开始位置下标, 结束位置下标)

 注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。

2. 快速体验

  mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.find('and')) 
print(mystr.find('and', 15, 30))
print(mystr.find('ands'))
具体示例如下:

 

 

 

 

 

index():检测某个⼦串是否包含在这个字符串中,如果在返回这个⼦串开始的位置下标,否则则 报异常
1. 语法
字符串序列.index(⼦串, 开始位置下标, 结束位置下标)
注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。


2. 快速体验
mystr = "hello xinhua and itcast and wushen and Python"
print(mystr.index('and'))
print(mystr.index('and', 15, 30))
print(mystr.index('ands'))
具体示例如下:

 

 

 rfind(): 和find()功能相同,但查找⽅向为右侧开始

 rindex():和index()功能相同,但查找⽅向为右侧开始。

count():返回某个⼦串在字符串中出现的次数

 

1. 语法

字符串序列.count(⼦串, 开始位置下标, 结束位置下标)

注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找


2. 快速体验

 

mystr = "hello xinhua and itcast and wushen and Python"
print(mystr.count('and'))
print(mystr.count('ands'))
print(mystr.count('and', 0, 20))
具体示例如下:

 

 

3.2 修改

所谓修改字符串,指的就是通过函数的形式修改字符串中的数据

 replace():替换

 1. 语法

 字符串序列.replace(旧⼦串, 新⼦串, 替换次数)

 注意:替换次数如果查出⼦串出现次数,则替换次数为该⼦串出现次数。

 

2. 快速体验

mystr = "hello xinhua and itcast and wushen and Python"
print(mystr.replace('and', 'he'))
print(mystr.replace('and', 'he', 10))
print(mystr)

 具体示例如下:

 

 注意:数据按照是否能直接修改分为可变类型和不可变类型两种。字符串类型的数据修改的时候 不能改变原有字符串,属于不能直接修改数据的类型即是不可变类型。

 

split():按照指定字符分割字符串。

1. 语法

字符串序列.split(分割字符, num)

注意:num表示的是分割字符出现的次数,即将来返回数据个数为num+1个。

2. 快速体验

mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.split('and'))

print(mystr.split('and', 2))

print(mystr.split(' '))

print(mystr.split(' ', 2))

具体示例如下:

 

注意:如果分割字符是原有字符串中的⼦串,分割后则丢失该⼦串。

 

•join():⽤⼀个字符或⼦串合并字符串,即是将多个字符串合并为⼀个新的字符串。

1. 语法

字符或⼦串.join(多字符串组成的序列)

2. 快速体验

list1 = ['wu', 'shen', 'bo', 'ke']
t1 = ('aa', 'b', 'cc', 'ddd')

print('_'.join(list1))

print('...'.join(t1))



•capitalize():将字符串第⼀个字符转换成⼤写。

mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.capitalize())
具体示例如下:

 

 

 注意:capitalize()函数转换后,只字符串第⼀个字符⼤写,其他的字符全都⼩写。

 

•title():将字符串每个单词⾸字⺟转换成⼤写。

mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.title())
具体示例如下:

 

 

•lower():将字符串中大写转小写
mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.lower())
具体示例如下:

 

 •upper():将字符串中小写转大写

mystr = "hello xinhua and itcast and wushen and Python"

print(mystr.upper())

 

•lstrip():删除字符串左侧空⽩字符。

1. lstrip(): 删除左侧空白字符

2. rstrip(): 删除右侧空白字符

3.strip():删除两侧空白字符

 

 

 

 

具体示例如下:

 

 

 

 

 •ljust():返回⼀个原字符串左对⻬,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串。

1. 语法

字符串序列.ljust(⻓度, 填充字符)

2. 输出效果:

 

 

• rjust():返回⼀个原字符串右对⻬,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串,语法和 ljust()相同。

•center():返回⼀个原字符串居中对⻬,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串,语 法和ljust()相同。

输出效果:

 3.3 判断

所谓判断即是判断真假,返回的结果是布尔型数据类型:True 或 False。

•startswith():检查字符串是否是以指定⼦串开头,是则返回 True,否则返回 False。如果设置开 始和结束位置下标,则在指定范围内检查。

1. 语法

字符串序列.startswith(⼦串, 开始位置下标, 结束位置下标)

2. 快速体验

 

mystr = "hello xinhua and itcast and it wushen and Python "
# 结果:True
print(mystr.startswith('hello'))
# 结果False
print(mystr.startswith('hellos'))
具体示例如下:

 

 

 

• endswith()::检查字符串是否是以指定⼦串结尾,是则返回 True,否则返回 False。如果设置开 始和结束位置下标,则在指定范围内检查。

1. 语法

字符串序列.endswith(⼦串, 开始位置下标, 结束位置下标)

2. 快速体验

mystr = "hello wushen and itcast and wushen and Python"
# 结果:True
print(mystr.endswith('Python'))
# 结果:False
print(mystr.endswith('python'))
# 结果:False
print(mystr.endswith('Pythons'))
具体示例如下:

 


• isalpha():如果字符串⾄少有⼀个字符并且所有字符都是字⺟则返回 True, 否则返回 False。

mystr1 = 'hello'
mystr2 = 'hello12345'
# 结果:True
print(mystr1.isalpha())
# 结果:False
print(mystr2.isalpha())
具体示例如下:

•sdigit()如果字符串只包含数字则返回 True 否则返回 False。

mystr1 = 'aaa12345'
mystr2 = '12345'
# 结果: False
print(mystr1.isdigit())
# 结果:True
print(mystr2.isdigit())
具体示例如下:


•salnum():如果字符串⾄少有⼀个字符并且所有字符都是字⺟或数字则返 回 True,否则返回 False。

mystr1 = 'aaa12345'
mystr2 = '12345-'
# 结果:True
print(mystr1.isalnum())
# 结果:False
print(mystr2.isalnum())
具体示例如下:

 


 

•isspace():如果字符串中只包含空⽩,则返回 True,否则返回 False。

mystr1 = '1 2 3 4 5'
mystr2 = ' '
# 结果:False
print(mystr1.isspace())
# 结果:True
print(mystr2.isspace())
具体示例如下:

 


 

 

 
 

 


 

 

 

 

 

 

 

 

 

 

 







posted @ 2021-10-24 20:58  吴神  阅读(182)  评论(0)    收藏  举报