字符串
字符串是 Python 中最常用的数据类型。我们可以使用引号 ( ' 或 " ) 来创建字符串。创建字符串很简单,只要为变量分配一个值即可
# 单引号
var1 = 'Hello World!'
# 双引号
var2 = "Python Runoob"
# 三引号
var3 = """hello world
i love you """
字符串的输入输出
格式化输出
name = "TOM"
age = 18
heigth = 180.5
print("我的名字是%s"%name)
print("我今年%d岁了"%age)
print("我的身高是%.2f"%heigth)
print("大家好,我叫{},我今年{}岁,我的升高是{}".format(name,age,heigth))
print(f"大家好,我叫{name},我今年{age}岁,我的升高是{heigth}")
输入input()
>>>name = input("请输入你的名字:")
>>>"tom"
>>>print(type(name))
>>>age = input("请输入你的年龄:")
>>>18
>>>print(type(age))
下标(索引)
“下标” ⼜叫 “索引” ,就是编号。⽐如⽕⻋座位号,座位号的作⽤:按照编号快速找到对应的座位。
索引是从0开始
var1 = "hello python"
print(var1[1])
print(var1[2])
print(var1[4])
# 输出结果
>>>e
>>>l
>>>o
切片
切⽚是指对操作的对象截取其中⼀部分的操作。字符串、列表、元组都⽀持切⽚操作
- 不包含结束位置下标对应的数据, 正负整数均可;
- 步⻓是选取间隔,正负整数均可,默认步⻓为1。
name = "hellopython"
print(name[2:5]) # 从2开始,到5结束(不会拿到5本身)
print(name[2:5:1]) # 从2开始,到5结束,步长为1(不会拿到5本身)
print(name[:5]) # 从0开始,下表为5结束(不会拿到本身)
print(name[1:]) # 从1开始,一直到结束
print(name[:]) # 拿取所有
print(name[::2]) # 从0开始,步长为2,拿取所有
print(name[:-1]) # 从0开始,到最后一个数结束(-1代表最后一个数,不包含-1本身)
print(name[-4:-1]) # 从倒数第四个开始,到倒数第一个结束(不包含-1本身)
print(name[::-1]) # 从-1开始,倒着打印字符串,步长为1
print(name[::-2]) # 从-1开始,倒着打印字符串,步长为2
常用操作方法
字符串的常⽤操作⽅法有查找、修改和判断三⼤类。
查找
所谓字符串查找⽅法即是查找⼦串在字符串中的位置或出现的次数。
- find():检测某个字符串是否包含在这个字符串中,如果在,返回这个字符串开始的位置下标,否则则返回-1。
语法
开始和结束位置下标可以省略,表示在整个字符串序列中查找。
# 字符串序列.find(⼦串, 开始位置下标, 结束位置下标)
var = "hello and python and hello world"
print(var.find("and")) # 查找到and首字母下标
print(var.find("and",8,20)) # 查找到下标为8-20,and首字母下标
print(var.find("ors")) # 查找ors,如果没有,则返回-1
- index():检测某个⼦串是否包含在这个字符串中,如果在返回这个⼦串开始的位置下标,否则则报异常。
语法
注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。
# 字符串序列.index(⼦串, 开始位置下标, 结束位置下标)
var = "hello and python and hello world"
print(var.index("and")) # 查找到and首字母下标
print(var.index("and",8,20)) # 查找到下标为8-20,and首字母下标
print(var.index("ors")) # 查找ors,如果没有,则报错
- count():返回某个⼦串在字符串中出现的次数
语法
注意:开始和结束位置下标可以省略,表示在整个字符串序列中查找。
# 字符串序列.count(⼦串, 开始位置下标, 结束位置下标)
var = "hello and python and hello world"
print(var.count("and")) # 查看在字符串var中,and出现了多少次
print(var.count("ands")) # 如果没有,则返回0次
print(var.count("and",8,20)) # 在一个区间内查找and出现的次数
拓展 了解即可
var = "hello and python and hello world"
# rfind(): 和find()功能相同,但查找⽅向为右侧开始。
print(var.rfind("and"))
# rindex():和index()功能相同,但查找⽅向为右侧开始。
print(var.rindex("and"))
修改
对字符串当中的内容进行修改
- replace():替换内容
语法
注意:替换次数如果超出⼦串出现次数,则替换次数为该⼦串出现次数。
# 字符串序列.replace(旧⼦串, 新⼦串, 替换次数)
var = "hello and python and hello world"
print(var.replace("and","和")) # 将里面所有的and替换为和
print(var.replace("and","和",1)) # 将and替换为和,只替换一次
注意:数据按照是否能直接修改分为可变类型和不可变类型两种。字符串类型的数据修改的时候不能改变原有字符串,属于不能直接修改数据的类型即是不可变类型。
- split():按照指定字符分割字符串。
语法
注意:num表示的是分割字符出现的次数
# 字符串序列.split(分割字符, num)
var = "hello and python and hello world"
print(var.split("and")) # 以and为界,分隔开其他字符串,返回一个列表
print(var.split("and",1)) # 以and为界,分隔开其他字符串,只分割一次,返回一个列表
- join():⽤⼀个字符或⼦串合并字符串,即是将多个字符串合并为⼀个新的字符串。
语法
# 字符或⼦串.join(多字符串组成的序列)
list1 = ["hello", "python", "i", "love", "you"]
t1 = ("hello", "python", "i", "love", "you")
set1 = {"hello", "python", "i", "love", "you"}
print("__".join(list1)) # 将列表转化为字符串,并且使用指定符号隔开
print(",".join(t1)) # 将元组转化为字符串,并且使用指定符号隔开
print("|".join(set1)) # 将集合转化为字符串,并且使用指定符号隔开
大小写转换
- capitalize():将字符串第⼀个字符转换成⼤写。
var = "hello and python and hello world"
print(var.capitalize()) # 将字符串第⼀个字符转换成⼤写。
- title():将字符串每个单词⾸字⺟转换成⼤写。
var = "hello and python and hello world"
print(var.title()) # 将字符串每个单词⾸字⺟转换成⼤写。
- upper():将字符串中⼩写转⼤写。
var = "hello and python and hello world"
print(var.upper()) # 将字符串中⼩写转⼤写。
- lower():将字符串中⼤写转⼩写。
var = "hello and python and hello world"
print(var.lower()) # 将字符串中⼤写转⼩写。
- lstrip():删除字符串左侧空⽩字符。
var = " hello and python and hello world "
print(var.lstrip()) # 删除左侧空格
- rstrip():删除字符串右侧空⽩字符。
var = " hello and python and hello world "
print(var.rstrip()) # 删除右侧空格
- strip():删除字符串两侧空⽩字符。
var = " hello and python and hello world "
print(var.strip()) # 删除两侧空格
- ljust():返回⼀个原字符串左对⻬,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串
- rjust():返回⼀个原字符串右对⻬,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串
- center():返回⼀个原字符串居中,并使⽤指定字符(默认空格)填充⾄对应⻓度 的新字符串
语法
# 字符串序列.ljust(⻓度, 填充字符)
var = "hello"
print(var.ljust(10,"_")) # 左对齐
print(var.rjust(10,"_")) # 右对齐
print(var.center(10,"_")) # 居中对齐
判断
- startswith():检查字符串是否是以指定⼦串开头
语法
# 字符串序列.startswith(⼦串, 开始位置下标, 结束位置下标)
var = "hello and python and hello world"
print(var.startswith("hello")) # 开头是hello,返回True
print(var.startswith("and")) # 开头不是and,返回False
print(var.startswith("and",6,20)) # 在索引6-20,开头是and,返回True
- endswith():检查字符串是否是以指定⼦串结尾
语法
var = "hello and python and hello world"
print(var.endswith("and")) # 结尾不是and,返回False
print(var.endswith("world")) # 结尾时world,返回True
print(var.endswith("and",0,9)) # 在0到9的索引范围(不包括9),是and结尾,返回True
- isalpha():如果字符串所有字符都是字⺟则返回 True, 否则返回 False。
语法
mystr1 = 'hello'
mystr2 = 'hello12345'
print(mystr1.isalpha()) # 结果:True
print(mystr2.isalpha()) # 结果:False
- isdigit():如果字符串只包含数字则返回 True 否则返回 False。
语法
mystr1 = 'aaa12345'
mystr2 = '12345'
print(mystr1.isdigit()) # 结果: False
print(mystr2.isdigit()) # 结果:True
- isalnum():如果字符串所有字符都是字⺟或数字则返 回 True,否则返回False。
语法
mystr1 = 'aaa12345'
mystr2 = '12345-'
print(mystr1.isalnum()) # 结果:True
print(mystr2.isalnum()) # 结果:False
- isspace():如果字符串中只包含空⽩,则返回 True,否则返回 False。
语法
mystr1 = '1 2 3 4 5'
mystr2 = ' '
print(mystr1.isspace()) # 结果:False
print(mystr2.isspace()) # 结果:True
字符串运算
a = "Hello",b = "Python"
+ | 字符串连接 | >>>a + b | 'HelloPython' |
---|---|---|---|
[] | 通过索引获取字符串中字符 | >>>a[1] | 'e' |
[ : ] | 截取字符串中的一部分 | >>>a[1:4] | 'ell' |
in | 成员运算符 - 如果字符串中包含给定的字符返回 True | >>>"H" in a | True |
not in | 成员运算符 - 如果字符串中不包含给定的字符返回 True | >>>"M" not in a | True |
r | 取消转义 | >>>r“你\n好” | 你\n好 |
% | 格式字符串 |