系列文章目录
- Python数据类型:编程新手的必修课
- 深入探索Python字符串:技巧、方法与实战
- Python 函数基础详解
- Python正则表达式详解:掌握文本匹配的魔法
- Python文件操作宝典:一步步教你玩转文件读写
- Python面向对象基础与魔法方法详解
- Python面向对象进阶:深入解析面向对象三要素——封装、继承与多态
- Python进阶之旅:深入理解变量作用域、垃圾回收、拷贝机制与异常处理
- Python函数进阶:四大高阶函数、匿名函数、枚举、拉链与递归详解
- 从零开始学迭代器生成器:打造高效、易读的Python代码
- Python进阶:深入剖析闭包与装饰器的应用与技巧
- PyMySQL:连接Python与MySQL的桥梁
概念
字符串: 由一系列字符组成的不可变序列容器
不可变:
1.没有增删改方法
2.所有的操作都不会直接作用于原数据
序列:
有序的排列,支持索引和切片操作
输入与格式化输出
输入:
input("提示语")
input接收过来的数据类型就是一个字符串
格式化输出:
1.%格式化法:
占位符:%s字符串 %d整型 %f浮点型(默认保留6位小数) %.2f保留两位小数
使用:在字符串最后 %(参数1,参数2……) 如果整个字符串中只有一个参数需要传递,可以省略()
2. format格式化法:
占位符:{}
使用:在字符串最后 .format(参数1,参数2……)
3.f格式化法:
占位符:{参数}
使用:在字符串最前 f
索引与切片
索引:
语法:字符串[索引]
特点:从左往右,从0开始;从右往左,从-1开始
切片:
语法:字符串[起始下标:结束下标:步长]
特点:
1. 取头不取尾,取不到结束下标对应的数据
2. 步长不写默认为1,步长可以是正负数
3. 下标可以正负数混搭
4. [n:m]:从下标为n的位置开始取到下标为m的前一位
5. [n:]:从下标为n的位置开始取到字符串结尾
6. [:m]:从字符串开头取到下标为m的前一位
7. [:]、[::]:取整个字符串
8. [::-1]:将整个字符串反转
常用方法
查询类方法
1.index:str.index(substring, beg=0, end=len(string))返回开始的索引值
2.find:str.find(str, beg=0, end=len(string)) 返回开始的索引值
3.count:str.count(sub, start= 0,end=len(string)) 返回子串出现的次数
index():
查找字符串中第一次出现的子字符串的位置
str.index(sub,start,end) ---返回整数
参数:
sub —— 查找的子字符串
start —— 索引的起始位置,默认为0
end —— 索引的结束位置,默认为字符串的长度
find():
找字符串中指定的子字符串sub第一次出现的位置,可以规定字符串的索引查找范围。若无则返回 -1。
str.find(sub,start,end) -> int 返回整数
参数:
- sub —要索引的子字符串。
- start —索引的起始位置。默认值为0。
- end —索引的结束位置。默认值为字符串长度len(str)。[start,end) 不包括end。
rfind():
查找字符串中指定的子字符串sub最后一次出现的位置,可以规定字符串的索引查找范围。若无则返回 -1。
str.rfind(sub,start,end) -> int 返回整数
参数:
- sub —要索引的子字符串
- start —索引的起始位置,默认值为0
- end —索引的结束位置。默认值为字符串长度len(str)。[start,end) 不包括end。
count():
统计字符串里某个字符出现的次数。
my_str.count(str, start=0, end=len(mystr))
参数:
str —— 为要统计的字符(可以是单字符,也可以是多字符)
star —— 为索引字符串的起始位置,默认参数为0
end —— 为索引字符串的结束位置,默认参数为字符串长度即len(str)
判别类方法
startswith:是否以某个字符串为开头
endswith:是否以某个字符串为结尾
isupper:是大写字母吗
islower:是小写字母吗
istitle:字符串是标题化的吗
isalpha:是全字母吗
isalnum:是全字母或全数字或全字母数字吗
isdigit:是数字吗
isspace:只包含空白字符(空格 /n /t等)吗
startswith():
判断字符串是否以指定字符或子字符串开头。
str.endswith("suffix", start, end) 或
str[start,end].endswith("suffix") 用于判断字符串中某段字符串是否以指定字符或子字符串结尾。
—> bool 返回值为布尔类型(True,False)
参数:
- suffix — 后缀,可以是单个字符,也可以是字符串,还可以是元组("suffix"中的引号要省略)。
- start —索引字符串的起始位置。
- end — 索引字符串的结束位置。
endswith():
判断字符串是否以指定字符或子字符串结尾。
str.endswith("suffix", start, end)
或str[start,end].endswith("suffix")
用于判断字符串中某段字符串是否以指定字符或子字符串结尾。
—> bool 返回值为布尔类型(True,False)
isupper():
检测字符串中的字母是否全由大写字母组成。(字符串中可包含非字母字符)。字符串中包含至少一个区分大小写的字符,且所有这些区分大小写的字符都是大写,则返回 True,否则返回 False。
str.isupper() -> bool 返回值为布尔类型(True,False)
islower():
检测字符串中的字母是否全由小写字母组成。(字符串中可包含非字母字符)字符串中包含至少一个区分大小写的字符,且所有这些区分大小写的字符都是小写,则返回 True,否则返回 False。
str.islower() -> bool 返回值为布尔类型(True,False)
istitle():
检测判断字符串中所有单词的首字母是否为大写,且其它字母是否为小写,字符串中可以存在其它非字母的字符。若字符串中所有单词的首字母为大写,且其它字母为小写,则返回 True,否则返回 False.
str.istitle() -> bool 返回值为布尔类型(True,False)
isalpha():
检测字符串是否只由字母组成。字符串中至少有一个字符且所有字符都是字母则返回 True,否则返回 False。
str.isalpha() -> bool 返回值为布尔类型(True,False)
isalnum():
检测字符串是否由字母和数字组成。str中至少有一个字符且所有字符都是字母或数字则返回 True,否则返回 False
str.isalnum() -> bool 返回值为布尔类型(True,False)
isdigit():
检测字符串是否只由数字组成.字符串中至少有一个字符且所有字符都是数字则返回 True,否则返回 False。
str.isdigit() -> bool 返回值为布尔类型(True,False)
isspace():
检测字符串是否只由空格组成。若字符串中只包含空格,则返回 True,否则返回 False。
str.isspace() -> bool 返回值为布尔类型(True,False)
调整类方法
capitalize:将字符串的第一个字符变大写,其他字母变小写
title:使字符串标题化(字符串中所有单词首字母大写,其他小写)
upper:变成大写
lower:变成小写
center:该方法返回一个原字符串居中,并使用空格填充至长度 width 的新字符串。
capitalize():
将字符串的第一个字母变成大写,其余字母变为小写。
str.capitalize()
title():
返回一个满足标题格式的字符串。即所有英文单词首字母大写,其余英文字母小写。
str.title()
upper():
将字符串中的所有小写字母转换为大写字母
str.upper()
lower():
将字符串中的所有大写字母转换为小写字母
str.lower()
center():
返回一个长度为width,两边用fillchar(单字符)填充的字符串,即字符串str居中,两边用fillchar填充。若字符串的长度大于width,则直接返回字符串str
str.center(width , "fillchar")
- width —— 指定字符串长度。
- fillchar —— 要填充的单字符,默认为空格。
操作类方法
replace(str1,str2):把str1替换为str2
split(str,num):以str分割字符串,num可以指定分割几次
join:str.join(sequence):将序列中的元素以指定的字符连接生成一个新的字符串
strip:只能删除开头或是结尾的字符,不能删除中间部分的字符
ljust:返回一个原字符串左对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串
rjust:返回一个原字符串右对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串
replace():
把 mystr 中的 str1 替换成 str2,如果 count 指定,则替换不超过 count 次.
my_str.replace(str1, str2, mystr.count(str1))
split():
拆分字符串。通过指定分隔符sep对字符串进行分割,并返回分割后的字符串列表。
str.split(sep=None, maxsplit=-1) [n]
参数:
sep —— 分隔符,默认为空格,但不能为空即('')
maxsplit —— 最大分割参数,默认参数为-1
[n] —— 返回列表中下标为n的元素。列表索引的用法
join():
将iterable变量的每一个元素后增加一个str字符串。
sep.join(iterable)
- sep——分隔符。可以为空。
- iterable—— 要连接的变量 ,可以是 字符串,元组,字典,列表等。
strip():
该函数的作用是去除字符串开头和结尾处指定的字符,不会去除字符串中间对应的字符
str.strip(chars)
参数:chars -- 要去除的字符 默认为空格或换行符。
lstrip():
lstrip() 方法用于截掉字符串左边的空格或指定字符。
str.lstrip(chars)
参数:chars--要去除的字符 默认为空格或换行符。
rstrip():
删除 str 字符串末尾的指定字符(默认为空格)
str.rstrip(chars)
参数:chars --要去除的字符 默认为空格或换行符。
ljust():
返回一个原字符串左对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。
str.ljust(width, fillchar) -> str 返回一个新的字符串
- width —— 指定字符串的输出长度。
- fillchar—— 将要填充的单字符,默认为空格。
rjust():
返回一个原字符串右对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。
str.ljust(width, fillchar)
- width —— 指定字符串的输出长度。
- fillchar—— 将要填充的单字符,默认为空格。
补充
字符串 + 字符串 拼接
字符串 * 数字 复制
字符 in 字符串:判断字符是否在字符串中
字符 not in 字符串:判断字符是否不在字符串中
len(字符串):统计字符串的长度、统计字符串中字符的个数