系列文章目录
第一章 初识python
第二章 变量
第三章 基础语句
文章目录
- 4.1认识字符串
- 字符串特征
- 4.2字符串输出
- 4.3字符串输入
- 4.4下标
- 4.5切片
- 4.6常用操作方法
- 查找
- 修改
- 修改大小写转换
- 字符串对齐
- 删除空白字符
- 判断
4.1认识字符串
字符串是 Python 中最常用的数据类型。我们一般使用引号来创建字符串。创建字符串很简单,只要为变量分配一个值即可
a = 'hello world'
b = "abcdefg"
print(type(a))
print(type(b))
注意: 控制台显示结果为<class ‘str’>,即数据类型为str(字符串)。
字符串特征
- 一对引号字符串
name1 = 'Tom'
name2 ="Rose"
- 三引号字符串
name3 = ''' Tom '''
name4 = """ Rose """
a = ''' i am Tom,
nice to meet you! '''
b = """ i am Rose,
nice to meet you! """
4.2字符串输出
print('hello xy')
name = '清风微泫'
print('我的名字是%s' % name)
print(f'我的名字是{name}')
4.3字符串输入
在python中,使用input()
接收用户输入
s = input('请输入内容:')
print(f'您输入的内容是{s}')
print(type(s))
mood = input('请输入您的心情:')
print(f'您输入的心情是{mood}')
print(type(mood))
4.4下标
“下标”又叫“索引”或叫”索引值”,就是编号。比如火车座位号,座位号的作用: 按照编号快速找到对应的座位。同理,下标的作用即是通过下标快速找到对应的数据。
注意:下标从0开始,如果是从后面开始-1代表最后一个
4.5切片
切片是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作.
语法
序列[开始位置下标:结束位置下标:步长]
注意
1.不包含结束位置下标对应的数据,正负整数均可。(左闭右开区间)
2. 步长是选取间隔,正负整数均可,默认步长为1。步长可省略不写
3. 如果不写开始,默认从0开始选取
4. 如果不写结束,表示选取到最后
5. 如果不写开始和结束,表示选取所有
6. 如果步长为负数表示倒数选取
7. 下标-1表示最后一个数据,依次向前类推
8. 如果选取方向(下标开始到结束的方向)和步长的方向冲突,则无法选取数据。从-4开始到-1结束,选取方向为从左到右侧,但是-1步长:从右向左选取。
str1="zwxhxy"
# 得到整个字符串数据
print(str1)
# 下标得到的是下标为某个数字的数据
print(str1[3]) # h
# 得到zwxh 这3个数据该怎么办?用切片
print(str1[0:3]) # zwx
print(str1[0:3:2]) # zx
print(str1[0:3:3]) # z
print(str1[0:3:4]) # z
print(str1[2:]) #xhxy
print(str1[:5]) # zwxhx
print(str1[:]) # zwxhxy
print("------------")
print(str1[::-1]) # yxhxwz
print(str1[-4:-1]) # xhx
print(str1[-4:-1:1]) # xhx
print(str1[-4:-1:-1]) # 不能选取出数据
print(str1[-1:-4:-1]) # yxh
4.6常用操作方法
字符串的常用操作方法有查找、修改和判断三大类
查找
所谓字符串查找方法即是查找子串在字符串中的位置或出现的次数。
注意: 开始和结束位置下标可以省略,表示在整个字符串序列中查找
-
find(): 检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则返回
-1
。
语法: 字符串序列.find(子串,开始位置下标,结束位置下标) -
index(): 检测某个子串是否包含在这个字符串中,如果在返回这个子串开始的位置下标,否则则报异常
(报错)
。
语法: 字符串序列.index(子串,开始位置下标,结束位置下标) -
rfind(): 和find()功能相同,但查找方向为右侧开始。没找到返回
-1
-
rindex(): 和index()功能相同,但查找方向为右侧开始。可能
报错
-
count(): 返回某个子串在字符串中出现的次数
语法: 字符串序列.count(子串,开始位置下标,结束位置下标)
mystr = 'I wander in your yard, looking forward to meeting you'
# find
print(mystr.find('you')) # 12
print(mystr.find('you', 20)) # 50
print(mystr.find('oo', 16, 40)) #24
print(mystr.find('xy')) # -1
# index
print("------index----------")
print(mystr.index("xy"))
修改
所谓修改字符串,指的就是通过函数的形式修改字符串中的数据
- replace(): 替换
语法: 字符串序列.replace(旧子串,新子串,替换次数)
返回值: 新的字符串
注意
1.替换次数如果查出子串出现次数,则替换次数为该子串出现次数。
2.数据按照是否能直接修改分为可变类型
和不可变类型
两种。字符串类型
的数据修改的时候不能改变原有字符串,属于
不能直接修改数据的类型即是不可变类型
。
3.原有字符串的数据并没有做到修改,修改后的数据是replace函数的返回值
4.替换次数如果超出子串出现次数,表示替换所有这个子串
- split():按照指定字符分割字符串
语法: 字符串序列.split(分割字符,num)
返回值: list列表,丢失分割字符
注意
1.num表示的是分割字符出现的次数,即将来返回数据个数为num+1个。
2. 如果分割字符是原有字符串中的子串,分割后则丢失该子串。
- join(): 用一个字符或子串合并字符串,即是将多个字符串合并为一个新的字符串
语法: 字符或子串.join(多字符串组成的序列)
返回值:新的字符串
修改大小写转换
- capitalize(): 将字符串第一个字符转换成大写。
返回值:字符串
mystr = “
h
ello world and itcast and itheima andP
ython”
# 结果:H
ello world and itcast and itheima andp
ython
print(mystr.capitalize())
注意: capitalize()函数转换后,只字符串第一个字符大写
,其他的字符全都小写
。
- title(): 将字符串每个单词首字母转换成大写
返回值:字符串
mystr = “hello world and itcast and itheima and Python”
# 结果: Hello World And Itcast And Itheima And Python
print(mystr.title())
- lower(): 将字符串中大写转小写
返回值:字符串
mystr = “hello world and itcast and itheima and Python”
# 结果: hello world and itcast and itheima and python
print(mystr.lower())
- upper(): 将字符串中小写转大写
返回值:字符串
mystr = “hello world and itcast and itheima and Python”
# 结果: HELLO WORLD AND ITCAST AND ITHEIMA AND PYTHON
print(mystr.upper())
字符串对齐
- ljust(): 返回一个原字符串左对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串。
语法: 字符串序列.ljust(长度,填充字符)
返回值:字符串
mystr = "hello"
newstr = mystr.ljust(10, "*")
print(newstr)
# hello*****
- rjust(): 返回一个原字符串右对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串,语法和ljust()相同。
- center(): 返回一个原字符串居中对齐,并使用指定字符(默认空格)填充至对应长度 的新字符串,语法和ljust()相同。注意不是绝对的居中
删除空白字符
- lstrip(): 删除字符串左侧空白字符
返回值:字符串
mystr = " I wander in your yard, looking forward to meeting you"
print(mystr.lstrip())
# I wander in your yard, looking forward to meeting you
- rstrip(): 删除字符串右侧空白字符
返回值:字符串
mystr = "I wander in your yard, looking forward to meeting you "
newstr=mystr.rstrip()
print(newstr)
#I wander in your yard, looking forward to meeting you
- strip(): 删除字符串两侧空白字符
返回值:字符串
mystr = " I wander in your yard, looking forward to meeting you "
newstr=mystr.strip()
print(newstr)
#I wander in your yard, looking forward to meeting you
判断
所谓判断即是判断真假,返回的结果是布尔型数据类型: True 或 False。
-
startswith(): 检查字符串是否是以指定子串
开头
,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
语法: 字符串序列.startswith(子串,开始位置下标,结束位置下标) -
endswith(): 检查字符串是否是以指定子串
结尾
,是则返回 True,否则返回 False。如果设置开始和结束位置下标,则在指定范围内检查。
语法:字符串序列.endswith(子串,开始位置下标,结束位置下标)
mystr = "hello"
num = mystr.startswith("h") # True
num = mystr.startswith("h", 1) # False
print(num)
print(type(num)) # bool
-
isalpha(): 如果字符串至少有一个字符并且所有字符都是
字母
则返回 True, 否则返回 False。
语法: 字符串序列.isalpha() -
isdigit(): 如果字符串只包含
数字
则返回 True 否则返回 False。
语法:字符串序列.isdigit() -
isalnum(): 如果字符串至少有一个字符并且所有字符都是
字母或数字
则返 回 True.否则返回False。
字符串序列.isalnum() -
isspace():如果字符串中只包含
空白(空格)
,则返回 True,否则返回 False。
字符串序列.isspace()