python一些常用方法.docx
- 文档编号:13682043
- 上传时间:2023-06-16
- 格式:DOCX
- 页数:16
- 大小:31.78KB
python一些常用方法.docx
《python一些常用方法.docx》由会员分享,可在线阅读,更多相关《python一些常用方法.docx(16页珍藏版)》请在冰点文库上搜索。
python一些常用方法
1.list方法
一、创建一个列表只要把逗号分隔的不同的数据项使用方括号括起来即可。
如下所示:
复制代码代码如下:
list1=['physics','chemistry',1997,2000];list2=[1,2,3,4,5];list3=["a","b","c","d"];
与字符串的索引一样,列表索引从0开始。
列表可以进行截取、组合等。
二、访问列表中的值使用下标索引来访问列表中的值,同样你也可以使用方括号的形式截取字符,如下所示:
复制代码代码如下:
#!
/usr/bin/pythonlist1=['physics','chemistry',1997,2000];list2=[1,2,3,4,5,6,7];
print"list1[0]:
",list1[0]print"list2[1:
5]:
",list2[1:
5]
以上实例输出结果:
复制代码代码如下:
list1[0]:
physicslist2[1:
5]:
[2,3,4,5]
三、更新列表你可以对列表的数据项进行修改或更新,你也可以使用append()方法来添加列表项,如下所示:
复制代码代码如下:
#!
/usr/bin/python
list=['physics','chemistry',1997,2000];
print"Valueavailableatindex2:
"printlist[2];list[2]=2001;print"Newvalueavailableatindex2:
"printlist[2];
以上实例输出结果:
复制代码代码如下:
Valueavailableatindex2:
1997Newvalueavailableatindex2:
2001
四、删除列表元素可以使用del语句来删除列表的的元素,如下实例:
复制代码代码如下:
#!
/usr/bin/python
list1=['physics','chemistry',1997,2000];
printlist1;dellist1[2];print"Afterdeletingvalueatindex2:
"printlist1;
以上实例输出结果:
复制代码代码如下:
['physics','chemistry',1997,2000]Afterdeletingvalueatindex2:
['physics','chemistry',2000]
五、Python列表脚本操作符列表对+和*的操作符与字符串相似。
+号用于组合列表,*号用于重复列表。
如下所示:
Python表达式
结果
描述
len([1,2,3])
3
长度
[1,2,3]+[4,5,6]
[1,2,3,4,5,6]
组合
['Hi!
']*4
['Hi!
','Hi!
','Hi!
','Hi!
']
重复
3in[1,2,3]
True
元素是否存在于列表中
forxin[1,2,3]:
printx,
123
迭代
六、Python列表截取Python的列表截取与字符串操作类型,如下所示:
复制代码代码如下:
L=['spam','Spam','SPAM!
']
操作:
Python表达式
结果
描述
L[2]
'SPAM!
'
读取列表中第三个元素
L[-2]
'Spam'
读取列表中倒数第二个元素
L[1:
]
['Spam','SPAM!
']
从第二个元素开始截取列表
七、Python列表操作的函数和方法列表操作包含以下函数:
1、cmp(list1,list2):
比较两个列表的元素2、len(list):
列表元素个数3、max(list):
返回列表元素最大值4、min(list):
返回列表元素最小值5、list(seq):
将元组转换为列表列表操作包含以下方法:
1、(obj):
在列表末尾添加新的对象2、(obj):
统计某个元素在列表中出现的次数3、(seq):
在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)4、(obj):
从列表中找出某个值第一个匹配项的索引位置5、(index,obj):
将对象插入列表6、(obj=list[-1]):
移除列表中的一个元素(默认最后一个元素),并且返回该元素的值7、(obj):
移除列表中某个值的第一个匹配项8、():
反向列表中元素9、([func]):
对原列表进行排序
字典
一、什么是字典
字典是Python语言中唯一的映射类型。
映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表。
字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象,其中也可包括其他容器类型。
字典类型与序列类型的区别:
1.存取和访问数据的方式不同。
2.序列类型只用数字类型的键(从序列的开始按数值顺序索引);3.映射类型可以用其他对象类型作键(如:
数字、字符串、元祖,一般用字符串作键),和序列类型的键不同,映射类型的键直4.接或间接地和存储数据值相关联。
5.映射类型中的数据是无序排列的。
这和序列类型是不一样的,序列类型是以数值序排列的。
6.映射类型用键直接“映射”到值。
字典是Python中最强大的数据类型之一。
二、如何创建字典和给字典赋值
简单地说字典就是用大括号包裹的键值对的集合。
(键值对也被称作项)一般形式:
复制代码代码如下:
adict={}adict={key1:
value2,key2:
value2,…}
或用dict()函数,如,adict=dict()或adict=dict((['x',1],['y',2]))这样写对吗adict=dict(['x',1],['y',2])。
关键字参数创建字典,如:
adict=dict(name='allen',age='40′)或用fromkeys()方法,如,adict={}.fromkeys((‘x','y'),-1)这样创建的字典的value是一样的,若不给值,默认为None。
特点:
1、键与值用冒号“:
”分开;2、项与项用逗号“,”分开;3、字典中的键必须是唯一的,而值可以不唯一。
复制代码代码如下:
adict={‘name':
'allen',‘name':
'lucy',‘age':
'40′}与bdict={‘name':
'allen',‘name2′:
'allen',‘age':
'40′}
注意:
如果字典中的值为数字,最好使用字符串数字形式,如:
'age':
'040′而不用‘age':
040
三、字典的基本操作
1、如何访问字典中的值adict[key]形式返回键key对应的值value,如果key不在字典中会引发一个KeyError。
2、如何检查key是否在字典中
a、has_key()方法形如:
(‘name')有–>True,无–>Falseb、in、notin形如:
'name'inadict有–>True,无–>False
3、如何更新字典
a、添加一个数据项(新元素)或键值对adict[new_key]=value形式添加一个项b、更新一个数据项(元素)或键值对adict[old_key]=new_valuec、删除一个数据项(元素)或键值对deladict[key]删除键key的项/deladict删除整个字典(key)删除键key的项并返回key对应的value值
四、映射类型操作符
标准类型操作符(+,-,*,<,>,<=,>=,==,!
=,and,or,not)
a、字典不支持拼接和重复操作符(+,*)b、字典的比较操作先比较字典的长度也就是字典的元素个数键比较值比较例子:
复制代码代码如下:
adict={}bdict={‘name':
'allen',‘age':
'40′}cmp(adict,bdict)<–>-1or>–>1or==–>0
五、映射相关的函数
1、len()返回字典的长度2、hash()返回对象的哈希值,可以用来判断一个对象能否用来作为字典的键3、dict()工厂函数,用来创建字典
六、字典的方法
1、()返回一个包含字典所有KEY的列表;2、()返回一个包含字典所有value的列表;3、()返回一个包含所有(键,值)元祖的列表;4、()删除字典中的所有项或元素;5、()返回一个字典浅拷贝的副本;6、(seq,val=None)创建并返回一个新字典,以seq中的元素做该字典的键,val做该字典中所有键对应的初始值(默认为None);7、(key,default=None)返回字典中key对应的值,若key不存在字典中,则返回default的值(default默认为None);8、(key)如果key在字典中,返回True,否则返回False。
现在用in、notin;9、()、()、()与它们对应的非迭代方法一样,不同的是它们返回一个迭代子,而不是一个列表;10、(key[,default])和get方法相似。
如果字典中存在key,删除并返回key对应的vuale;如果key不存在,且没有给出default的值,则引发keyerror异常;11、(key,default=None)和set()方法相似,但如果字典中不存在Key键,由adict[key]=default为它赋值;12、(bdict)将字典bdict的键值对添加到字典adict中。
七、字典的遍历
1、遍历字典的key(键)
复制代码代码如下:
forkeyin():
printkey
2、遍历字典的value(值)
复制代码代码如下:
forvaluein():
printvalue
3、遍历字典的项(元素)
复制代码代码如下:
foritemin():
printitem
4、遍历字典的key-value
复制代码代码如下:
foritem,valuein():
print‘key=%s,value=%s'%(item,value)或foritem,valuein():
print‘key=%s,value=%s'%(item,value)
集合
set是一个无序的元素集合,支持并、交、差及对称差等数学运算,但由于set不记录元素位置,因此不支持索引、分片等类序列的操作。
初始化
复制代码代码如下:
s0=set()d0={}s1={0}s2={i%2foriinrange(10)}s=set('hi')t=set(['h','e','l','l','o'])print(s0,s1,s2,s,t,type(d0))
运行结果:
复制代码代码如下:
set(){0}{0,1}{'i','h'}{'e','o','l','h'}
提示、d0:
使用{}只能创建空字典,创建空集必须用set();、sl:
set中的元素是无序不重复的,可以利用这个特点去除列表中的重复元素。
运算操作
复制代码代码如下:
print(t),s&t)#交集print(t),s|t)#并集print(t),s-t)#差集print(t),s^t)#对称差集print(s2),s1<=s2)#子集print(s2),s1>=s2)#包含
运行结果:
复制代码代码如下:
{'h'}{'h'}{'l','h','i','o','e'}{'l','h','i','o','e'}{'i'}{'i'}{'i','l','o','e'}{'i','l','o','e'}TrueTrueFalseFalse
提示1.非运算符的方法接受任何可迭代对象作为参数,如([0,1]);2.其他等价操作:
(t)与s|=t,(t)与s&=t,(t)与s-=t,(t)与s^=t等。
基本方法
复制代码代码如下:
s={0}print(s,len(s))#获取集合中的元素的总数("x")#添加一个元素print(s)([1,2,3])#添加多个元素print(s,"x"ins)#成员资格测试("x")#去掉一个元素print(s,"x"notins)("x")#如果集合存在指定元素,则删除该元素c=()#复制集合print(s,())#弹出集合中的一个不确定元素,如果原集合为空则引发KeyError()#删除集合中的元素print(s,c)
运行结果:
复制代码代码如下:
{0}1{0,'x'}{0,'x',1,2,3}True{0,1,2,3}True{1,2,3}0set(){0,1,2,3}
Str字符串方法
1、去空格及特殊符号
复制代码代码如下:
().lstrip().rstrip(',')
2、复制字符串
复制代码代码如下:
#strcpy(sStr1,sStr2)sStr1='strcpy'sStr2=sStr1sStr1='strcpy2'printsStr2
3、连接字符串
复制代码代码如下:
#strcat(sStr1,sStr2)sStr1='strcat'sStr2='append'sStr1+=sStr2printsStr1
4、查找字符
复制代码代码如下:
#strchr(sStr1,sStr2)#<0为未找到sStr1='strchr'sStr2='s'nPos=(sStr2)printnPos
5、比较字符串
复制代码代码如下:
#strcmp(sStr1,sStr2)sStr1='strchr'sStr2='strch'printcmp(sStr1,sStr2)
6、扫描字符串是否包含指定的字符
复制代码代码如下:
#strspn(sStr1,sStr2)sStr1=''sStr2='456'#sStr1andcharsbothinsStr1andsStr2printlen(sStr1andsStr2)
7、字符串长度
复制代码代码如下:
#strlen(sStr1)sStr1='strlen'printlen(sStr1)
8、将字符串中的大小写转换
复制代码代码如下:
()#小写()#大写()#大小写互换()#首字母大写(S)#这是模块中的方法。
它把S用split()函数分开,然后用capitalize()把首字母变成大写,最后用join()合并到一起#实例:
#strlwr(sStr1)sStr1='JCstrlwr'sStr1=()#sStr1=()printsStr1
9、追加指定长度的字符串
复制代码代码如下:
#strncat(sStr1,sStr2,n)sStr1='12345'sStr2='abcdef'n=3sStr1+=sStr2[0:
n]printsStr1
10、字符串指定长度比较
复制代码代码如下:
#strncmp(sStr1,sStr2,n)sStr1='12345'sStr2='123bc'n=3printcmp(sStr1[0:
n],sStr2[0:
n])
11、复制指定长度的字符
复制代码代码如下:
#strncpy(sStr1,sStr2,n)sStr1=''sStr2='12345'n=3sStr1=sStr2[0:
n]printsStr1
12、将字符串前n个字符替换为指定的字符
复制代码代码如下:
#strnset(sStr1,ch,n)sStr1='12345'ch='r'n=3sStr1=n*ch+sStr1[3:
]printsStr1
13、扫描字符串
复制代码代码如下:
#strpbrk(sStr1,sStr2)sStr1='cekjgdklab'sStr2='gka'nPos=-1forcinsStr1:
ifcinsStr2:
nPos=(c)breakprintnPos
14、翻转字符串
复制代码代码如下:
#strrev(sStr1)sStr1='abcdefg'sStr1=sStr1[:
:
-1]printsStr1
15、查找字符串
复制代码代码如下:
#strstr(sStr1,sStr2)sStr1='abcdefg'sStr2='cde'print(sStr2)
16、分割字符串
复制代码代码如下:
#strtok(sStr1,sStr2)sStr1='ab,cde,fgh,ijk'sStr2=','sStr1=sStr1[(sStr2)+1:
]printsStr1#或者s='ab,cde,fgh,ijk'print(','))
17、连接字符串
复制代码代码如下:
delimiter=','mylist=['Brazil','Russia','India','China']print(mylist)
18、PHP中addslashes的实现
复制代码代码如下:
defaddslashes(s):
d={'"':
'\\"',"'":
"\\'","\0":
"\\\0","\\":
"\\\\"}return''.join(c,c)forcins)s="John'Johny'Doe\"SuperJoe\")\\\0"printsprintaddslashes(s)
19、只显示字母与数字
复制代码代码如下:
defOnlyCharNum(s,oth=''):
s2=();fomart='abcdefghijklmnopqrstuvwxyz09'forcins2:
ifnotcinfomart:
s=(c,'');returns;print(OnlyStr("a000aa-b"))
20、截取字符串
复制代码代码如下:
str='09′printstr[0:
3]#截取第一位到第三位的字符printstr[:
]#截取字符串的全部字符printstr[6:
]#截取第七个字符到结尾printstr[:
-3]#截取从头开始到倒数第三个字符之前printstr[2]#截取第三个字符printstr[-1]#截取倒数第一个字符printstr[:
:
-1]#创造一个与原字符串顺序相反的字符串printstr[-3:
-1]#截取倒数第三位与倒数第一位之前的字符printstr[-3:
]#截取倒数第三位到结尾printstr[:
-5:
-3]#逆序截取,具体啥意思没搞明白
21、字符串在输出时的对齐
复制代码代码如下:
(width,[fillchar])#输出width个字符,S左对齐,不足部分用fillchar填充,默认的为空格。
(width,[fillchar])#右对齐(width,[fillchar])#中间对齐(width)#把S变成width长,并在右对齐,不足部分用0补足
22、字符串中的搜索和替换
复制代码代码如下:
(substr,[start,[end]])#返回S中出现substr的第一个字母的标号,如果S中没有substr则返回-1。
start和end作用就相当于在S[start:
end]中搜索(substr,[start,[end]])#与find()相同,只是在S中没有substr时,会返回一个运行时错误(substr,[start,[end]])#返回S中最后出现的substr的第一个字母的标号,如果S中没有substr则返回-1,也就是说从右边算起的第一次出现的substr的首字母标号(substr,[start,[end]])(substr,[start,[end]])#计算substr在S中出现的次数(oldstr,newstr,[count])#把S中的oldstar替换为newstr,count为替换次数。
这是替换的通用形式,还有一些函数进行特殊字符的替换([chars])#把S中前后chars中有的字符全部去掉,可以理解为把S前后chars替换为None([chars])([chars])([tabsize])#把S中的tab字符替换没空格,每个tab替换为tabsize个空格,默认是8个
23、字符串的分割和组合
复制代码代码如下:
([sep,[maxsplit]])#以sep为分隔符,把S分成一个list。
maxsplit表示分割的次数。
默认的分割符为空白字符([sep,[maxsplit]])([keepends])#把S按照行分割符分为一个list,keepends是一个bool值,如果为真每行后而会保留行分割符。
(seq)#把seq代表的序列──字符串序列,用S连接起来
24、字符串的mapping,这一功能包含两个函数
复制代码代码如下:
(from,to)#返回一个256个字符组成的翻译表,其中from中的字符被一一对应地转换成to,所以from和to必须是等长的。
(table[,deletechars])#使用上面的函数产后的翻译表,把S进行翻译,并把deletechars中有的字符删掉。
需要注意的是,如果S为unicode字符串,那么就不支持deletechars参数,可以使用把某个字符翻译为None的方式实现相同的功能。
此外还可以使用codecs模块的功能来创建更加功能强大的翻译表。
25、字符串还有一对编码和解码的函数
复制代码代码如下:
([encoding,[errors]])#其中encoding可以有多种值,比如gb2312gbkgb18030bz2zlibbig5bzse64等都支持。
errors默认值为"strict",意思是UnicodeError。
可能的值还有'ignore','replace','xmlcharrefreplace','backslashreplace'和所有的通过注册的值。
这一部分内容涉及codecs模块,不是特明白([encoding,[errors]])
26、字符串的测试、判断函数,这一类函数在string模块中没有,这些函数返回的都是bool值
复制代码代码如下:
(prefix[,start[,end]])#是否以prefix开头(suffix[,start[,end]])#以suffix结尾()#是否全是字母和数字,并至少有一个字符()#是否全是字母,并至少有一个字符()#是否全是数字,并至少有一个字符()#是否全是空白字符,并至少有一个字符()#S中的字母是否全是小写()#S中的字母是否便是大写(
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- python 一些 常用 方法
![提示](https://static.bingdoc.com/images/bang_tan.gif)