如有字符串mystr = 'hello world itcast and itcastcpp',以下是常见的操作
<1>find
检测 str 是否包含在 mystr中,如果是返回开始的索引值,否则返回-1
mystr.find(str, start=0, end=len(mystr))[外链图片转存失败(img-vL0FN9Iy-1563444347254)(…/Images/Snip20160814_215.png)]
[外链图片转存失败(img-ltXwqD3o-1563444347256)(…/Images/Snip20160814_216.png)]
<2>index
跟find()方法一样,只不过如果str不在 mystr中会报一个异常.
mystr.index(str, start=0, end=len(mystr))[外链图片转存失败(img-OJHxt8YT-1563444347256)(…/Images/Snip20160814_217.png)]
<3>count
返回 str在start和end之间 在 mystr里面出现的次数
mystr.count(str, start=0, end=len(mystr))[外链图片转存失败(img-6J7lr6FT-1563444347257)(…/Images/Snip20160814_218.png)]
<4>replace
把 mystr 中的 str1 替换成 str2,如果 count 指定,则替换不超过 count 次.
mystr.replace(str1, str2, mystr.count(str1))[外链图片转存失败(img-CN5CPN4A-1563444347258)(…/Images/Snip20160814_214.png)]
<5>split
以 str 为分隔符切片 mystr,如果 maxsplit有指定值,则仅分隔 maxsplit 个子字符串
mystr.split(str=" ", 2)[外链图片转存失败(img-MMNklV3Z-1563444347258)(…/Images/Snip20160814_211.png)]
<6>capitalize
把字符串的第一个字符大写
mystr.capitalize()[外链图片转存失败(img-2b3o5OZ5-1563444347259)(…/Images/Snip20160814_219.png)]
<7>title
把字符串的每个单词首字母大写
>>> a = "hello itcast" >>> a.title() 'Hello Itcast'<8>startswith
检查字符串是否是以 obj 开头, 是则返回 True,否则返回 False
mystr.startswith(obj)[外链图片转存失败(img-T5gtPAiK-1563444347259)(…/Images/Snip20160814_221.png)]
<9>endswith
检查字符串是否以obj结束,如果是返回True,否则返回 False.
mystr.endswith(obj)[外链图片转存失败(img-BHb7dU0z-1563444347260)(…/Images/Snip20160814_222.png)]
<10>lower
转换 mystr 中所有大写字符为小写
mystr.lower()[外链图片转存失败(img-I4e0KFFR-1563444347261)(…/Images/Snip20160814_223.png)]
<11>upper
转换 mystr 中的小写字母为大写
mystr.upper()[外链图片转存失败(img-zRn6lhJe-1563444347261)(…/Images/Snip20160814_224.png)]
<12>ljust
返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
mystr.ljust(width)[外链图片转存失败(img-BKuOFekM-1563444347262)(…/Images/Snip20160814_225.png)]
<13>rjust
返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
mystr.rjust(width)[外链图片转存失败(img-Bmf6z3eF-1563444347262)(…/Images/Snip20160814_226.png)]
<14>center
返回一个原字符串居中,并使用空格填充至长度 width 的新字符串
mystr.center(width)[外链图片转存失败(img-D07qzKSE-1563444347263)(…/Images/Snip20160814_220.png)]
<15>lstrip
删除 mystr 左边的空白字符
mystr.lstrip()[外链图片转存失败(img-mtTurkqJ-1563444347264)(…/Images/Snip20160814_227.png)]
<16>rstrip
删除 mystr 字符串末尾的空白字符
mystr.rstrip()[外链图片转存失败(img-i8v7HV96-1563444347265)(…/Images/Snip20160814_228.png)]
<17>strip
删除mystr字符串两端的空白字符
>>> a = "\n\t itcast \t\n" >>> a.strip() 'itcast'<18>rfind
类似于 find()函数,不过是从右边开始查找.
mystr.rfind(str, start=0,end=len(mystr) )[外链图片转存失败(img-VDyEZkcZ-1563444347266)(…/Images/Snip20160814_233.png)]
<19>rindex
类似于 index(),不过是从右边开始.
mystr.rindex( str, start=0,end=len(mystr))[外链图片转存失败(img-E21H9opY-1563444347267)(…/Images/Snip20160814_235.png)]
<20>partition
把mystr以str分割成三部分,str前,str和str后
mystr.partition(str)[外链图片转存失败(img-J4reKBj6-1563444347268)(…/Images/Snip20160814_230.png)]
<21>rpartition
类似于 partition()函数,不过是从右边开始.
mystr.rpartition(str)[外链图片转存失败(img-oQhYzP8Z-1563444347269)(…/Images/Snip20160814_232.png)]
<22>splitlines
按照行分隔,返回一个包含各行作为元素的列表
mystr.splitlines()[外链图片转存失败(img-jQqvsHq8-1563444347270)( …/Images/Snip20160814_229.png)]
<23>isalpha
如果 mystr 所有字符都是字母 则返回 True,否则返回 False
mystr.isalpha()[外链图片转存失败(img-EHUE9Lmc-1563444347271)(…/Images/Snip20160814_237.png)]
<24>isdigit
如果 mystr 只包含数字则返回 True 否则返回 False.
mystr.isdigit()[外链图片转存失败(img-OsILj0Qj-1563444347271)(…/Images/Snip20160814_238.png)]
<25>isalnum
如果 mystr 所有字符都是字母或数字则返回 True,否则返回 False
mystr.isalnum()[外链图片转存失败(img-DHpgdgJt-1563444347272)(…\Images\Snip20160814_236.png)]
<26>isspace
如果 mystr 中只包含空格,则返回 True,否则返回 False.
mystr.isspace()[外链图片转存失败(img-iCAYlxhu-1563444347273)(…/Images/Snip20160814_240.png)]
<27>join
mystr 中每个字符后面插入str,构造出一个新的字符串
mystr.join(str)[外链图片转存失败(img-RaHULEbz-1563444347274)(…/Images/Snip20160814_242.png)]
列表中存放的数据是可以进行修改的,比如"增"、“删”、“改”"
("增"append, extend, insert)
append
通过append可以向列表添加元素
demo:
#定义变量A,默认有3个元素 A = ['xiaoWang','xiaoZhang','xiaoHua'] print("-----添加之前,列表A的数据-----") for tempName in A: print(tempName) #提示、并添加元素 temp = input('请输入要添加的学生姓名:') A.append(temp) print("-----添加之后,列表A的数据-----") for tempName in A: print(tempName)结果:
[外链图片转存失败(img-Zt1Emu4v-1563444347275)(…/Images/01-第3天-2.gif)]
extend
通过extend可以将另一个集合中的元素逐一添加到列表中
>>> a = [1, 2] >>> b = [3, 4] >>> a.append(b) >>> a [1, 2, [3, 4]] >>> a.extend(b) >>> a [1, 2, [3, 4], 3, 4]insert
insert(index, object) 在指定位置index前插入元素object
>>> a = [0, 1, 2] >>> a.insert(1, 3) >>> a [0, 3, 1, 2](“改”)
修改元素的时候,要通过下标来确定要修改的是哪个元素,然后才能进行修改
demo:
#定义变量A,默认有3个元素 A = ['xiaoWang','xiaoZhang','xiaoHua'] print("-----修改之前,列表A的数据-----") for tempName in A: print(tempName) #修改元素 A[1] = 'xiaoLu' print("-----修改之后,列表A的数据-----") for tempName in A: print(tempName)结果:
-----修改之前,列表A的数据----- xiaoWang xiaoZhang xiaoHua -----修改之后,列表A的数据----- xiaoWang xiaoLu xiaoHua("查"in, not in, index, count)
所谓的查找,就是看看指定的元素是否存在
in, not in
python中查找的常用方法为:
in(存在),如果存在那么结果为true,否则为falsenot in(不存在),如果不存在那么结果为true,否则falsedemo
#待查找的列表 nameList = ['xiaoWang','xiaoZhang','xiaoHua'] #获取用户要查找的名字 findName = input('请输入要查找的姓名:') #查找是否存在 if findName in nameList: print('在字典中找到了相同的名字') else: print('没有找到')说明:
in的方法只要会用了,那么not in也是同样的用法,只不过not in判断的是不存在
index, count
index和count与字符串中的用法相同
>>> a = ['a', 'b', 'c', 'a', 'b'] >>> a.index('a', 1, 3) # 注意是左闭右开区间 Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: 'a' is not in list >>> a.index('a', 1, 4) 3 >>> a.count('b') 2 >>> a.count('d') 0("删"del, pop, remove)
类比现实生活中,如果某位同学调班了,那么就应该把这个条走后的学生的姓名删除掉;在开发中经常会用到删除这种功能。
列表元素的常用删除方法有:
del:根据下标进行删除pop:删除最后一个元素remove:根据元素的值进行删除demo:(del)
movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情'] print('------删除之前------') for tempName in movieName: print(tempName) del movieName[2] print('------删除之后------') for tempName in movieName: print(tempName)结果:
------删除之前------ 加勒比海盗 骇客帝国 第一滴血 指环王 霍比特人 速度与激情 ------删除之后------ 加勒比海盗 骇客帝国 指环王 霍比特人 速度与激情demo:(pop)
movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情'] print('------删除之前------') for tempName in movieName: print(tempName) movieName.pop() print('------删除之后------') for tempName in movieName: print(tempName)结果:
------删除之前------ 加勒比海盗 骇客帝国 第一滴血 指环王 霍比特人 速度与激情 ------删除之后------ 加勒比海盗 骇客帝国 第一滴血 指环王 霍比特人demo:(remove)
movieName = ['加勒比海盗','骇客帝国','第一滴血','指环王','霍比特人','速度与激情'] print('------删除之前------') for tempName in movieName: print(tempName) movieName.remove('指环王') print('------删除之后------') for tempName in movieName: print(tempName)结果:
------删除之前------ 加勒比海盗 骇客帝国 第一滴血 指环王 霍比特人 速度与激情 ------删除之后------ 加勒比海盗 骇客帝国 第一滴血 霍比特人 速度与激情(sort, reverse)
sort方法是将list按特定顺序重新排列,默认为由小到大,参数reverse=True可改为倒序,由大到小。
reverse方法是将list逆置。
>>> a = [1, 4, 2, 3] >>> a [1, 4, 2, 3] >>> a.reverse() >>> a [3, 2, 4, 1] >>> a.sort() >>> a [1, 2, 3, 4] >>> a.sort(reverse=True) >>> a [4, 3, 2, 1]Python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号,列表使用方括号。
>>> aTuple = ('et',77,99.9) >>> aTuple ('et',77,99.9)[外链图片转存失败(img-M4nlFwIu-1563444347276)(…/Images/Snip20160815_301.png)]
[外链图片转存失败(img-h2ntTh6Y-1563444347277)(…/Images/Snip20160815_303.png)]
说明: python中不允许修改元组的数据,包括不能删除其中的元素。
count, index
index和count与字符串和列表中的用法相同
>>> a = ('a', 'b', 'c', 'a', 'b') >>> a.index('a', 1, 3) # 注意是左闭右开区间 Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: tuple.index(x): x not in tuple >>> a.index('a', 1, 4) 3 >>> a.count('b') 2 >>> a.count('d') 0 的元组与列表类似,不同之处在于**元组的元素不能修改**。元组使用小括号,列表使用方括号。 ```python >>> aTuple = ('et',77,99.9) >>> aTuple ('et',77,99.9)[外链图片转存中…(img-M4nlFwIu-1563444347276)]
[外链图片转存中…(img-h2ntTh6Y-1563444347277)]
说明: python中不允许修改元组的数据,包括不能删除其中的元素。
count, index
index和count与字符串和列表中的用法相同
>>> a = ('a', 'b', 'c', 'a', 'b') >>> a.index('a', 1, 3) # 注意是左闭右开区间 Traceback (most recent call last): File "<stdin>", line 1, in <module> ValueError: tuple.index(x): x not in tuple >>> a.index('a', 1, 4) 3 >>> a.count('b') 2 >>> a.count('d') 0