关注作者,持续阅读作者的文章,学习更多知识!
https://blog.csdn.net/weixin_53306029?spm=1001.2014.3001.5343
字符串是一种表示文本数据的类型,在python中可以用以下三种方式表示字符串。
1.转义字符
对于单引号或者双引号这些特殊的符号,我们可以对他们进行转义。例如,对字符串中的单引号进行转义:
print('Ok sir, let\'s go! ')
注意:print函数自身带了一个换行,如果使用print()就可以输出一个换行
2.输入输出
#字符串的格式化输出
name1 ="小明"
name2="小红"
print("大家好,我叫%s"%name1)
print("大家好,我们是%s和%s"%(name1,name2))
#字符串的输入
#username=input("请输入用户名")
#print(username)
#字符串的存储方式
贴士:字符串中的每个字符都对应一个下标,下标编号是从0开始的
3.切片
切片操作基本表达式:
object[start_index:end_index:step]
含义:object[起始:结束:步长]
切片选取的区间属于左闭右开型,即从"起始"位开始,到"结束"位的前一位结束(不包含结束位本身)
Python可切片对象的索引方式
包括:正索引和负索引两部分.
如下图所示,以list对象a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]为例:
参数解释:
object[起始:结束:步长]
-
step:正负数均可,其绝对值大小决定了切取数据时的‘‘步长”,而正负号决定了“切取方向”,正表示“从左往右”取值,负表示“从右往左”取值。当step省略时,默认为1,即从左往右以步长1取值。“切取方向非常重要!”“切取方向非常重要!”“切取方向非常重要!”,重要的事情说三遍!
-
start_index:表示起始索引(包含该索引对应值);该参数省略时,表示从对象“端点”开始取值,至于是从“起点”还是从“终点”开始,则由step参数的正负决定,step为正从“起点”开始,为负从“终点”开始。
-
end_index:表示终止索引(不包含该索引对应值);该参数省略时,表示一直取到数据“端点”,至于是到“起点”还是到“终点”,同样由step参数的正负决定,step为正时直到“终点”,为负时直到“起点”。
4.字符串内建函数
1.find函数:检测字符串是否包括子字符串
格式:str.find(str, beg=0, end=len(string))
参数如下:
str – 指定检索的字符串。
beg – 开始索引,默认为0。
end – 结束索引,默认为字符串的长度。
找到则返回索引位置,找不到返回-1。
#eg:
s1="svsvhsjf"
result=s1.find("m",0,len(s1))
print(result)
>>>-1
2.index函数:检测字符串是否包括子字符串
格式:str.index(str, beg=0, end=len(string))
参数如下:
str – 指定检索的字符串。
beg – 开始索引,默认为0。(包括)
end – 结束索引,默认为字符串的长度。(不包括)
找到则返回索引位置,找不到抛出异常。
#eg:
s2="svsvhsjf"
result=s2.index("f",0,len(s2))
print(result)
>>>7
3.count函数:统计字符串中某个字符、字符串的个数
格式:str.count(sub, start= 0, end=len(string))
参数如下:
sub – 搜索的子字符串
start – 字符串开始搜索的位置(包括)
end – 字符串中结束搜索的位置(不包括)
#eg:
s3="svsvhsjf"
result=s3.count("s",0,len(s3))
print(result)
>>>3
s4="svsvhsjfsviihsvr"
result=s4.count("sv",0,len(s4))#在s中找"sv"的次数
print(result)
>>>4
4.replace函数:将旧字符串替换为新字符串
格式:str.replace(old, new[, max])
参数如下:
old需要进行更换的旧子串
new新的子串,将取代旧的子字符串(子串可以为空)
max如果可选参数max值给出,表示出现前max的次数的子串被替换
#eg:
str="monkey likes lion,wow!!!monkey likes lion very much!!"
print(str.replace("li","ha"))
print(str.replace("li","ha",3))
print(str.replace('li',''))
print(str)
输出结果
注意:运行结果来看,replace函数不会改变原始字符串的值,如果需要使用替换后的字符串,需要将其重新赋值给一个新的变量
5.splite函数:通过指定分隔符对字符串进行切片
格式:str.split(str="", num=string.count(str))
参数如下:
str – 分隔符。默认为所有空字符,如空格,tab等。
num – 分割次(默认:有多少个str分割多少次)
eg:
string = “www.gziscas.com.cn”
1.以’.'为分隔符
print(string.split(’.’))
[‘www’, ‘gziscas’, ‘com’, ‘cn’]
2.分割两次
print(string.split(’.’,2))
[‘www’, ‘gziscas’, ‘com.cn’]
3.分割两次,并取序列为1的项
print(string.split(’.’,2)[1])
gziscas
4.分割两次,并把分割后的三个部分保存到三个文件
u1, u2, u3 =string.split(’.’,2)
print(u1)—— www
print(u2)—— gziscas
print(u3) ——com.cn
6.capitalize:第一个字符大写,其他字符小写
#格式:
str.capitalize()
#eg:
s5="this is hello"
print(s5.capitalize())
7.title:所有单词首字母大写,其余字母小写
#格式:
str.title()
#eg:
s6="this is hello"
print(s6.title())
8.startswith:检查字符串是否以指定子串开头
格式:str.startswith(str, beg=0,end=len(string))
参数如下:
str – 检测的字符串,该参数可以是一个字符串或者是一个元素。
strbeg – 可选参数用于设置字符串检测的起始位置。(包括)
strend – 可选参数用于设置字符串检测的结束位置。(不包括)
返回 true 和 false
#eg:
s7="you are my dad!"
print(s7.startswith("y",0,len(s7)))
>>>True
9.endswith:检查字符串是否以指定子串结尾
格式:str.endswith(suffix,beg=0,end=len(string))
参数如下:
suffix – 该参数可以是一个字符串或者是一个元素。
strbeg – 可选参数用于设置字符串检测的起始位置。(包括)
strend – 可选参数用于设置字符串检测的结束位置。(不包括)
#eg:
s8="you are my mam!"
print(s8.endswith("am!",0,len(s8)))
>>>True
10.upper:将小写字母转为大写字母
格式:str.upper()
str1="sddhGYoon"
print(str1.upper())
11.lower:将大写字母转为小写字母
格式:str.lower()
str2="FIGGOPbO"
print(str2.lower())
12.对齐( ljust、rjust、center)
ljust:左对齐,使用空格填充至指定长度的新字符串
格式:str.ljust(width,fillchar)
参数如下:
width – 指定字符串长度。
fillchar – 填充字符,默认为空格。
注:字符串在右边进行填充
#eg:
str3="wXGUVHhoh"
print(str3.ljust(15,'#'))
print(str3.ljust(15))
rjust:右对齐,使用空格填充至指定长度的新字符串
#eg:
print(str3.rjust(15,'#'))
print(str3.rjust(15))
center:返回一个指定的宽度 width 居中的字符串
格式:str.center(width[, fillchar])
参数
width:表示包括 S 本身长度在内,字符串要占的总长度;
fillchar:作为可选参数,用来指定填充字符串时所用的字符,默认情况使用空格。
#eg:
str4="i am a boy"
print(str4.center(20,'-'))
13.截掉指定字符
lstrip:截掉字符串左边的空格或指定字符
格式:str.lstrip([chars])
#eg:
str5=" sohdf k "
str6="sohdf k"
print(str5.lstrip()) #默认截掉空格
print(str6.lstrip("so"))
rstrip:截掉字符串右边的空格或指定字符
格式:str.rstrip([chars])
#eg:
str5=" sohdf k "
str6="sohdf k"
print(str5.rstrip())
print(str6.rstrip("f k"))
strip:截掉字符串左右边的空格或指定字符
格式:str.strip([chars])
str5=" sohdf k "
str6="sohdf k"
print(str5.strip())
print(str6.strip('sok'))