目录
-
字符串的创建与驻留机制
交互模式:win+r cmd命令
s1='abc%'
s2='abc%'
print(s1 == s2)#Ture Pycharm对字符串进行了优化处理
字符串驻留机制的优缺点:
1、当需要值相同的字符串时,直接从字符串池里拿出来使用,避免频繁的创建和销毁,提升效率节约内存
2、但在python中,尽量少用加号“+”连接字符串,原因如下:在python中,String对象是定长对象,一旦创建,长度就不可变化,若是使用+号连接两个字符串,则会新开辟一段长度为两个字符串长度总和的内存,再将两个字符串memcpy进去。如果要连接N个String对象,则要进行N-1次内存申请和拷贝,影响性能。 官方推荐的是使用字符串的join方法,该方法对于连接一个list或tuple中的元素非常有效,它会先统计所有元素的长度,申请内存,然后拷贝,只创建一个字符串。
#拼接字符串,不推荐用+号,推荐用join()
a='123'
b=''.join(['456','789']) #'456'和'789'之间用空连接
print(b)
print(a.join(['456','789']))#'456'和'789'之间用a连接
-
字符串的常用操作
-
字符串的查询操作
s='hello,hello'
print(s.index('lo'))#3
print(s.find('lo'))#3
print(s.rindex('lo'))#9
print(s.rfind('lo'))#9
#建议使用find,不会抛异常
#print(s.index('k'))#ValueError: substring not found
print(s.find('k'))#返回-1
#print(s.rindex('k'))#ValueError: substring not found
print(s.rfind('k'))#返回-1
-
字符串的大小写转换操作
转换后会产生新的字符串对象
#转换
s='hello,python'
a=s.upper()
print(a,id(a))
print(s,id(s))
b=s.lower()
print(b,id(b))
print(s,id(s))
print(b==s)#True
print(b is s)#False
c='hello,Python'
print(c.swapcase())
print(c.title())
-
字符串内容对齐操作
#居中对齐
s='hello,Python'
print(s.center(20,'*'))
#左对齐
print(s.ljust(20,'*'))
#右对齐
print(s.rjust(20,'*'))
print(s.zfill(20))#左边用0填充
print('-8910'.zfill(8))#0填充到-号之后,-号占一位
-
字符串劈分操作
#split从左侧开始劈分,rsplit从右侧开始劈分
s='hello world Python'
lst=s.split()#默认劈分符为空格,返回值是列表,列表内有三个元素
print(lst)
s1='hello|world|Python'
print(s1.split())#默认劈分符为空格,返回值是列表,列表内有1个元素
print(s1.split(sep='|'))#指定劈分符为|,返回值是列表,列表内有3个元素
print(s1.split(sep='|',maxsplit=1))#指定最大劈分次数为1,返回值是列表,列表内有2个元素,分一次,剩下的当做一个整体
print(s1.rsplit(sep='|',maxsplit=1))
-
判断字符串操作