Python基础(中)
Posted Jonins
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python基础(中)相关的知识,希望对你有一定的参考价值。
前言
print(" _ooOoo_ ") print(" o8888888o ") print(" 88 . 88 ") print(" (| -_- |) ") print(" O\\\\ = /O ") print(" ____/`---\'\\\\____ ") print(" . \' \\\\| |// `. ") print(" / \\\\||| : |||// \\\\ ") print(" / _||||| -:- |||||- \\\\ ") print(" | | \\\\\\\\\\\\ - /// | | ") print(" | \\\\_| \'\'\\\\---/\'\' | | ") print(" \\\\ .-\\\\__ `-` ___/-. / ") print(" ___`. .\' /--.--\\\\ `. . __ ") print(" ."" \'< `.___\\\\_<|>_/___.\' >\'"". ") print(" | | : `- \\\\`.;`\\\\ _ /`;.`/ - ` : | | ") print(" \\\\ \\\\ `-. \\\\_ __\\\\ /__ _/ .-` / / ") print(" ======`-.____`-.___\\\\_____/___.-`____.-\'====== ") print(" `=---=\' " ) print(" ") print(" ............................................. ") print(" 佛祖镇楼 国庆快乐 ")
字符串基础(String)
python中字符的定义使用单引号或者双引号都可以,例如:
str1="Hello" #或者 str2="Jonins"
注意:在python3中input获取键盘输入的数据,都以字符串的方式进行保存,即使输入的是数字。
下标&切片
1.下标
下标:可以理解为数组类数据类型内元素的索引。列表与元组支持下标索引,字符串是字符的数组,所以也支持下标索引。索引从0开始,而内存中实际存储如下:
2.切片
切片:是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。切片的语法格式如下:
1 变量名[起始:结束:步长]
注意:选取的区间属于左闭右开型,既从起始位开始,到结束位的前一位,不包含结束位本身。说明示例如下:
1 name=\'0123456789\' 2 print(name[0:3])#取下标0-2的字符 3 print(name[3:5])#取下标3-4的字符 4 print(name[3:])#取下标3开始到最后的字符 5 print(name[3:-3])#取下标3开始到倒数第3个之间的字符(不包含倒数第三) 6 print(name[3:-1:2])#取标3开始到倒数第一个之间间隔为2-1的字符(步长,默认是1,当指定的时取值是步长的值,可以理解为中间间隔(步长-1)) 7 print(name[-1::-1])#倒叙输出字符串
列表基础(List)
1.列表基础
列表类型的格式:
1 testList=[xxx,yyy,zzz....nnn]
列表支持切片和下标操作,而python比C语言的数组强大的地方在于列表中的元素可以是不同类型的:
1 tuple=[\'jonins01\',2,\'jonins02\',3.3] 2 print(tuple[2]) 3 tuple2=tuple[0:2] 4 print(tuple2)
2.列表的遍历
为了更有效的输出列表的每个数据,可以使用循环来完成,列表的遍历可以使用for循环或者while循环来实现,示例如下:
1 nameList=[\'jonins1\',\'jonins2\',\'jonins\'] 2 print(\'-----for循环遍历-----\') 3 for name in nameList: 4 print(name) 5 print(\'-----while循环遍历-----\') 6 i=0 7 while i<len(nameList): 8 print(nameList[i]) 9 i+=1
元组基础(Tuple)
1.元组基础
python的元组与列表类似,不同之处在于元组的元素不能修改。元组使用小括号,列表使用方括号。列表的格式如下:
1 tuple=(xxx,yyy,zzz....nnn)
python中不允许修改元组的数据,包括不能删除其中的元素。元组同样支持切片和下标操作。
1 tuple=(\'jonins1\',2,\'jonins\',3.3) 2 print(tuple[2]) 3 tuple2=tuple[0:] 4 print(tuple2)
2.元组的遍历
元组同样可以遍历,通过for循环和while循环都可以实现:
1 tuple=(\'jonins1\',2,\'jonins\',3.3) 2 print(\'-----for循环遍历-----\') 3 for t in tuple: 4 print(t) 5 print(\'-----while循环遍历-----\') 6 i=0 7 while i<len(tuple): 8 print(tuple[i]) 9 i+=1
字典基础(Dictionary)
1.字典基础
说明:字典是key/value键值对集合。字典和列表一样,都可以存储多个数据。列表中找某个元素是根据下标进行,而字典中找某个元素是根据key查找。字典的格式如下:
1 info={\'key1\':value1,\'key2\':value2,......\'keyn\':valuen}
示例:
1 info={\'name\':\'jonins\',\'age\':18,\'sex\':\'man\'} 2 print(info[\'age\'])
注意:
1.字典的键(key)可以是任何不可变类型。但不可重复。
2.字典的值(value)可以是任何类型。
3.若访问不存在的键(key)则会报错。
2.字典的遍历
字典提供内置的方法keys()、values()、items()方法,可以根据需求做所需要的遍历操作,示例如下:
1 info={\'name\':\'jonins\',3:18,\'sex\':\'man\'} 2 print(\'遍历字典的键(key)\') 3 for key in info.keys(): 4 print(key) 5 print(\'遍历字典的值(value)\') 6 for value in info.values(): 7 print(value) 8 print(\'遍历字典的项(元素)\') 9 for item in info.items(): 10 print(item)
字符串常用操作(String)
1.find&rfind
find() 方法检测字符串中是否包含子字符串 str ,如果指定 start(开始) 和 end(结束) 范围,则检查是否包含在指定范围内,如果指定范围内如果包含指定索引值,返回的是索引值在字符串中的起始位置。如果不包含索引值,返回-1。
rfind()方法类似于find()方法,不过是从右边开始查找。
语法格式:
1 myStr.find(str,start,end)
说明:
myStr:指定检索的字符串。
str:检测的字符串或字符。
start:开始索引,默认为0。
end: 结束索引,默认为字符串的长度。
示例如下:
1 stringInfo = \'hello my name is jonins\' 2 result = stringInfo.find(\'my\', 0, len(stringInfo)) 3 print(result)
2.index&rindex
跟find()方法一样,index()如果在检测字符或字符串不存在会报一个异常。
rindex()方法类似于index(),不过是从右边开始。
3.count
count() 方法用于统计字符串里某个字符出现的次数。可选参数为在字符串搜索的开始与结束位置。
语法格式:
1 myStr.count(str,start,end)
说明:
myStr:指定检索的字符串。
str:搜索的子字符串
start:字符串开始搜索的位置。默认为第一个字符,第一个字符索引值为0。
end:字符串中结束搜索的位置。字符中第一个字符的索引为 0。默认为字符串的最后一个位置。
示例如下:
1 stringInfo = \'hello my name is jonins\' 2 result = stringInfo.count(\'m\', 0, -1) 3 print(result)
4.replace
eplace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。
语法格式:
1 myStr.replace(old, new[, max])
说明:
myStr:指定替换的字符串。
old:将被替换的子字符串。
new:新字符串,用于替换old子字符串。
max :可选字符串, 替换不超过 max 次
示例如下:
1 stringInfo = \'jonins jonins jonins jonins \' 2 stringInfo=stringInfo.replace(\'jonins\',\'jon&ins\', 2) 3 print(stringInfo)
5.split
split()通过指定分隔符对字符串进行切片,如果参数num 有指定值,则仅分隔 num 个子字符串。返回分割后的字符串列表。
语法格式:
1 myStr.split(str, num)
说明:
myStr:指定分割的字符串。
str:分隔符,默认为所有的空字符,包括空格、换行(\\n)、制表符(\\t)等。
num:分割次数。
示例如下:
1 stringInfo = \'jonins jonins jonins jonins \' 2 stringInfoList=stringInfo.split(\' \', 2) 3 print(stringInfoList)
6.capitalize
capitalize()方法将字符串的第一个字母变成大写,其他字母变小写。示例如下:
1 stringInfo = \'jonins jonins jonins jonins \' 2 stringInfo=stringInfo.capitalize() 3 print(stringInfo)
7.title
title()方法返回"标题化"的字符串,所有单词的首个字母转化为大写,其余字母均为小写。示例如下:
1 stringInfo = \'jonins jonins jonins jonins \' 2 stringInfo=stringInfo.title() 3 print(stringInfo)
8.startswith&endswith
startswith()方法用于检查字符串是否是以指定子字符串开头,如果是则返回 True,否则返回 False。如果参数 start 和 end 指定值,则在指定范围内检查。
endswith() 方法用于判断字符串是否以指定后缀结尾,如果以指定后缀结尾返回True,否则返回False。如果参数 start 和 end 指定值,则在指定范围内检查。
语法格式:
1 myStr.startswith(str, start,end)#检测指定开始 2 myStr.endswith(str, start,end)#检测指定结尾
说明:
myStr:指定检索的字符串。
str:该参数可以是一个字符串或者是一个元素。
start:字符串中的开始位置。
end:字符中结束位置。
示例如下:
1 stringInfo = \'hello jonins\' 2 startFlag=stringInfo.startswith(\'hel\') 3 endFlag=stringInfo.endswith(\'ins\') 4 print(startFlag) 5 print(endFlag)
9.lower&upper
lower()方法转换字符串中所有大写字符为小写。
upper()方法将字符串中的小写字母转为大写字母。
示例如下:
1 stringInfo = \'heLlO jOnInS\' 2 lowerStr=stringInfo.lower() 3 upperStr=stringInfo.upper() 4 print(lowerStr) 5 print(upperStr)
10.ljust&rjust¢er
ljust()方法返回一个原字符串左对齐,并使用空格填充至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。
rjust()方法返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串。如果指定的长度小于字符串的长度则返回原字符串。
center()方法返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。
语法格式:
1 myStr.ljust(width,fillchar) 2 myStr.rjust(width,fillchar) 3 myStr.center(width,fillchar)
说明:
myStr:指定需对齐的字符串。
width:指定字符串长度。
fillchar:填充字符,默认为空格。
示例如下:
1 stringInfo = \'jonins\' 2 ljustStr=stringInfo.ljust(10)#左对齐 3 rjustStr=stringInfo.rjust(10)#右对齐 4 centerStr=stringInfo.center(10)#居中 5 print(\'-%s-\'%ljustStr) 6 print(\'-%s-\'%rjustStr) 7 print(\'-%s-\'%centerStr)
11.lstrip&rstrip&strip
lstrip()方法用于截掉字符串左边的空格或指定字符(默认为空格)。
rstrip()方法用于删除字符串末尾的指定字符(默认为空格)。
strip()方法用于移除字符串头尾指定的字符(默认为空格)或字符序列。该方法只能删除开头或是结尾的字符,不能删除中间部分的字符。
语法格式:
1 myStr.lstrip(chars)#删除左边的某字符 2 myStr.rstrip(chars)#删除右边的某字符 3 myStr.strip(chars)#删除两端的某字符
说明:
myStr:指定检索的字符串。
chars:指定移除的字符。
示例如下:
1 myStr = \' jonins \' 2 lstripStr=myStr.lstrip() 3 rstripStr=myStr.rstrip() 4 stripStr=myStr.strip() 5 print(\'-%s-\'%lstripStr) 6 print(\'-%s-\'%rstripStr) 7 print(\'-%s-\'%stripStr)
12.partition&rpartition
partition()方法用来根据指定的分隔符将字符串进行分割。如果字符串包含指定的分隔符,则返回一个3元的元组,第一个为分隔符左边的子串,第二个为分隔符本身,第三个为分隔符右边的子串。
rpartition()方法类似于partition(),不过是从右开始。示例如下:
1 myStr = \'my name is jonins\' 2 strTuple=myStr.partition(\'name\') 3 print(strTuple)
13.splitlines
splitlines()方法按照行(\'\\r\', \'\\r\\n\', \\n\')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
语法格式:
1 myStr.splitlines([keepends])
说明:
myStr:指定分割的字符串。
keepends :默认为 False,不包含换行符,如果为 True,则保留换行符。
示例如下:
1 myStr = \'hello \\n jonins\' 2 strList=myStr.splitlines() 3 print(strList)
14.isalpha&isdigit&isalnum&isspace
isalpha()方法检测字符串是否只由字母组成。
isdigit()方法检测字符串是否只由数字组成。
isalnum()方法检测字符串是否由字母和数字组成。
isspace()方法检测字符串是否只由空白字符组成
示例如下:
1 isalphaStr=\'abcd\'.isalpha()#判断是否只有字母 2 isdigitStr=\'1234\'.isdigit()#判断是否只有数字 3 isalnumStr=\'a1b2c3\'.isalnum()#判断是否只有字母和字母 4 isspaceStr=\' \'.isspace()#判断是否只有空白字符 5 print(isalphaStr) 6 print(isdigitStr) 7 print(isalnumStr) 8 print(isspaceStr)
15.join
join()方法用于将序列中的元素以指定的字符连接生成一个新的字符串。
语法格式:
1 str.join(sequence)
说明:
str:指定连接的字符。
sequence:要连接的元素序列。
示例如下:
1 strList=[\'my\',\'name\',\'is\',\'jonins\'] 2 str=\' \' 3 stringInfo=str.join(strList) 4 print(stringInfo)
列表常用操作(List)
1.添加元素(append&extend&insert)
append()方法用于在列表末尾添加新的对象。
extend()函数用于在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)。
insert()函数用于将指定对象插入列表的指定位置。
示例如下:
1 A=[\'1\',\'2\',\'3\',\'4\'] 2 A.append(\'5\')#尾部追加一个元素 3 print(A) 4 B=[\'101\',\'102\',\'103\'] 5 B.extend(A)#尾部追加一个集合 6 print(B) 7 B.insert(2,\'INSERT\')#在下标2处追加元素 8 print(B)
2.修改元素
修改元素的时候,要通过下标来确认要修改那个元素,然后才能进行修改,示例如下:
1 A=[\'1\',\'2\',\'3\',\'4\'] 2 A[0]=\'01\' 3 print(A)
3.查找元素(in¬ in&index&count)
可以使用python运算符(in、not in)来判断列表是否存在指定的元素,示例及说明如下:
in(包含):如果存在那么结果为Ture,否则为False。
not in(不包含):如果不存在那么结果为Ture,否则为False。
1 A=[\'1\',\'2\',\'3\',\'4\'] 2 flag1=\'2\' in A 3 flag2=\'2\' not in A 4 print(flag1) 5 print(flag2)
也可以使用python提供的index和count方法实现检测,具体使用方式与字符串中使用index和count方法的用法相同,示例及说明如下:
index()方法用于从列表中找出某个值第一个匹配项的索引位置。
count()方法用于统计某个元素在列表中出现的次数。
1 A=[\'1\',\'2\',\'3\',\'4\'] 2 flag1=A.index(\'3\') 3 flag2=A.count(\'3\') 4 print(flag1) 5 print(flag2)
4.删除元素(del&pop&remove)
del:根据下标进行删除。
pop:删除最后一个元素。
remove:根据元素的值进行删除。
示例如下:
1 A=[\'1\',\'2\',\'3\',\'4\',\'5\'] 2 del A[0]#根据下标删除元素 3 A.pop()#删除最后一个元素 4 A.remove(\'3\')#根据元素值删除元素 5 print(A)
5.排序(sort&reverse)
sort() 方法用于对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数。而reverse()方法用于反向列表中元素(逆置)。
语法格式:
1 list.sort(cmp=None, key=None, reverse=False)
说明:
cmp:可选参数, 如果指定了该参数会使用该参数的方法进行排序。
key:主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
reverse:排序规则,reverse = True 降序, reverse = False 升序(默认)。
示例如下:
1 A=[\'1\',\'2\',\'5\',\'4\',\'3\'] 2 A.reverse()#列表逆置 3 print(A) 4 A.sort()#列表升序排序 5 print(A) 6 A.sort(reverse=True)#列表降序排序 7 print(A)
元组常用操作(Tuple)
元组内置的函数index和count,它们的用法与字符串和列表中的用法相同。
字典常用操作(Dictionary)
1.修改元素
字典中的每个元素只要通过key(键)找到,即可修改。示例:
1 info={\'name\':\'jonins\',\'age\':\'18\'} 2 info[\'age\']=\'20\' 3 print(info)
2.添加元素
当指定key(键)来访问元素时若该键不存,则会报错。如果要添加元素,可以使用:
以上是关于Python基础(中)的主要内容,如果未能解决你的问题,请参考以下文章
在 Python 多处理进程中运行较慢的 OpenCV 代码片段