概念
字符串: 由一系列字符组成的不可变序列容器
不可变: 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(字符串):统计字符串的长度、统计字符串中字符的个数