【Python基础】Python初学者必须吃透这69个内置函数!
所謂內(nèi)置函數(shù),就是Python提供的, 可以直接拿來直接用的函數(shù),比如print,enumerate、format等。Python內(nèi)置的這些函數(shù)非常精巧且強(qiáng)大的,對(duì)初學(xué)者來說,經(jīng)常會(huì)忽略,但是偶爾會(huì)碰到,我也是用了一段時(shí)間python之后才發(fā)現(xiàn),哇還有這么好的函數(shù),每個(gè)函數(shù)都非常經(jīng)典,而且經(jīng)過嚴(yán)格測(cè)試,使用內(nèi)置函數(shù),不用自己閉門造車,并且代碼簡(jiǎn)潔易讀了很多,真是方便又實(shí)用,值得花時(shí)間進(jìn)行體系化研究學(xué)習(xí)。
初學(xué)者的代碼之所以寫的不簡(jiǎn)潔,不是因?yàn)閷W(xué)的不夠好,而是學(xué)的不夠多,很多內(nèi)置的東西都沒學(xué)透。
abs() | delattr() | hash() | memoryview() | set() |
all() | dict() | help() | min() | setattr() |
any() | dir() | hex() | next() | slice() |
ascii() | divmod() | id() | object() | sorted() |
bin() | enumerate() | input() | oct() | staticmethod() |
bool() | eval() | int() | open() | str() |
breakpoint() | exec() | isinstance() | ord() | sum() |
bytearray() | filter() | issubclass() | pow() | super() |
bytes() | float() | iter() | print() | tuple() |
callable() | format() | len() | property() | type() |
chr() | frozenset() | list() | range() | vars() |
classmethod() | getattr() | locals() | repr() | zip() |
compile() | globals() | map() | reversed() | __import__() |
complex() | hasattr() | max() | round() |
?
一、數(shù)字相關(guān)
01 數(shù)據(jù)類型
bool()
描述:測(cè)試一個(gè)對(duì)象是True, 還是False.bool 是 int 的子類。
語(yǔ)法:class bool([x])
參數(shù):x -- 要進(jìn)行轉(zhuǎn)換的參數(shù)。
bool([0,0,0]) True bool([]) False issubclass(bool, int) # bool 是 int 子類 True?
int()
描述:int() 函數(shù)用于將一個(gè)字符串或數(shù)字轉(zhuǎn)換為整型。x可能為字符串或數(shù)值,將x 轉(zhuǎn)換為一個(gè)普通整數(shù)。如果參數(shù)是字符串,那么它可能包含符號(hào)和小數(shù)點(diǎn)。如果超出了普通整數(shù)的表示范圍,一個(gè)長(zhǎng)整數(shù)被返回。
語(yǔ)法:int(x, base =10)
參數(shù):
x -- 字符串或數(shù)字。
base -- 進(jìn)制數(shù),默認(rèn)十進(jìn)制。
float()
描述:將一個(gè)字符串或整數(shù)轉(zhuǎn)換為浮點(diǎn)數(shù)
語(yǔ)法:class float([x])
參數(shù):x -- 整數(shù)或字符串
float(3) 3.0 float('123') 123.0?
complex()
描述:創(chuàng)建一個(gè)復(fù)數(shù)
語(yǔ)法:class complex([real[, imag]])
參數(shù):
real -- int, long, float或字符串;
imag -- int, long, float;
02 進(jìn)制轉(zhuǎn)換
bin()
描述:bin()?返回一個(gè)整數(shù) int 或者長(zhǎng)整數(shù) long int 的二進(jìn)制表示。將十進(jìn)制轉(zhuǎn)換為二進(jìn)制
語(yǔ)法:bin(x)
參數(shù):x -- int 或者 long int 數(shù)字
bin(2) '0b10'bin(20) '0b10100'oct()
描述:將十進(jìn)制轉(zhuǎn)換為八進(jìn)制 otc() 將給的參數(shù)轉(zhuǎn)換成八進(jìn)制
語(yǔ)法:oct(x)
參數(shù):x -- 整數(shù)。
oct(8) '0o10'oct(43) '0o53'hex()
描述:hex()?函數(shù)用于將10進(jìn)制整數(shù)轉(zhuǎn)換成16進(jìn)制,以字符串形式表示。
語(yǔ)法:hex(x)
參數(shù):x -- 10進(jìn)制整數(shù)。
將十進(jìn)制轉(zhuǎn)換為十六進(jìn)制 hex(43) '0x2b'#43等于2Bhex(15) '0xf'?
03 數(shù)學(xué)運(yùn)算
abs()
描述:返回?cái)?shù)字絕對(duì)值或復(fù)數(shù)的模
語(yǔ)法:abs( x )
參數(shù):x 數(shù)值表達(dá)式。
abs(-6) 6 abs(5j+4) 6.4031242374328485?
divmod()
描述:divmod() 函數(shù)把除數(shù)和余數(shù)運(yùn)算結(jié)果結(jié)合起來,返回一個(gè)包含商和余數(shù)的元組(a // b, a % b)。
語(yǔ)法:divmod(a, b)
參數(shù):a: 數(shù)字--被除數(shù)
? ? ? ? ?b: 數(shù)字--除數(shù)
divmod(11,3) (3, 2)divmod(20,4) (5, 0)?
round()
描述:round()?函數(shù)返回浮點(diǎn)數(shù)x的四舍五入值。
語(yǔ)法:round( x [, n] ?)
參數(shù):
x -- 數(shù)值表達(dá)式。
n --代表小數(shù)點(diǎn)后保留幾位
?
pow()
描述:pow(x,y)?方法返回x的y次方的值,等價(jià)于x**y。函數(shù)是計(jì)算x的y次方,如果z在存在,則再對(duì)結(jié)果進(jìn)行取模,其結(jié)果等效于pow(x,y) %z
語(yǔ)法:pow(x, y[, z])
參數(shù):
x -- 數(shù)值表達(dá)式。
y -- 數(shù)值表達(dá)式。
z -- 數(shù)值表達(dá)式。
sum()
描述:sum()?方法對(duì)系列進(jìn)行求和計(jì)算。
語(yǔ)法:sum(iterable[, start])
參數(shù):
iterable -- 可迭代對(duì)象,如:列表、元組、集合。
start -- 指定相加的參數(shù),如果沒有設(shè)置這個(gè)值,默認(rèn)為0。
?
min()
描述:min() 方法返回給定參數(shù)的最小值,參數(shù)可以為序列。
語(yǔ)法:min( x, y, z, .... )
參數(shù):
x -- 數(shù)值表達(dá)式。
y -- 數(shù)值表達(dá)式。
z -- 數(shù)值表達(dá)式。
?
max()
描述:max() 方法返回給定參數(shù)的最大值,參數(shù)可以為序列。
語(yǔ)法:max( x, y, z, .... )
參數(shù):
x -- 數(shù)值表達(dá)式。
y -- 數(shù)值表達(dá)式。
z -- 數(shù)值表達(dá)式。
?
二、數(shù)據(jù)結(jié)構(gòu)相關(guān)
01 序列數(shù)據(jù)類型
1)列表和元組
list()
描述:list() 函數(shù)創(chuàng)建列表或者用于將序列轉(zhuǎn)換為列表。
語(yǔ)法:list( iterable )
參數(shù):iterable -- 可迭代序列。
序列為元組時(shí) s=(123, 'xyz', 'zara', 'abc') list(S) [123, 'xyz', 'zara', 'abc']序列為字符串 s= '小伍哥真是帥,特別帥' list(s) ['小', '伍', '哥', '真', '是', '帥', ',', '特', '別', '帥'] 序列為字典 s = {'nanme':'小伍哥','age':30,'address':'Hangzhou'} list(s) ['nanme', 'age', 'address'] tuple() 描述:元組 tuple() 函數(shù)將列表轉(zhuǎn)換為元組。 語(yǔ)法:tuple( iterable ) 參數(shù):iterable -- 要轉(zhuǎn)換為元組的可迭代序列。 案例: tuple([1,2,3,4]) (1, 2, 3, 4)tuple({'a':2,'b':4}) #針對(duì)字典 會(huì)返回字典的key組成的tuple('a', 'b')tuple('小伍哥真是帥,特別帥')('小',?'伍',?'哥',?'真',?'是',?'帥',?',',?'特',?'別',?'帥')???2)集合數(shù)據(jù)類型
dict()
描述:創(chuàng)建數(shù)據(jù)字典
語(yǔ)法:
class dict(**kwarg)
class dict(mapping, **kwarg)
class dict(iterable, **kwarg)
參數(shù):
**kwargs -- 關(guān)鍵字
mapping -- 元素的容器。
iterable -- 可迭代對(duì)象。
?
set()
描述:set()?函數(shù)創(chuàng)建一個(gè)無(wú)序不重復(fù)元素集,可進(jìn)行關(guān)系測(cè)試,刪除重復(fù)數(shù)據(jù),還可以計(jì)算交集、差集、并集等。
語(yǔ)法:class set([iterable])
參數(shù):iterable -- 可迭代對(duì)象對(duì)象;
#返回一個(gè)set對(duì)象,可實(shí)現(xiàn)去重: a = [1,4,2,3,1] set(a) {1, 2, 3, 4}?
frozenset()
描述:frozenset()?返回一個(gè)凍結(jié)的集合,凍結(jié)后集合不能再添加或刪除任何元素。
語(yǔ)法:class frozenset([iterable])
參數(shù):iterable -- 可迭代的對(duì)象,比如列表、字典、元組等等。
創(chuàng)建一個(gè)不可修改的集合。 frozenset([1,1,3,2,3]) frozenset({1, 2, 3})?
3)字符串
str()
描述:str() 函數(shù)將對(duì)象轉(zhuǎn)化為適于人閱讀的形式。將字符類型、數(shù)值類型等轉(zhuǎn)換為字符串類型
語(yǔ)法:class str(object='')
參數(shù):object -- 對(duì)象。
integ = 100 str(integ) '100'dict = {'baidu': 'baidu.com', 'google': 'google.com'}; str(dict) "{'baidu': 'baidu.com', 'google': 'google.com'}"?
format()
描述:Python2.6 開始,新增了一種格式化字符串的函數(shù) str.format(),它增強(qiáng)了字符串格式化的功能。基本語(yǔ)法是通過?{}?和?:?來代替以前的?%?。使用format()來格式化字符串時(shí),使用在字符串中使用{}作為占位符,占位符的內(nèi)容將引用format()中的參數(shù)進(jìn)行替換。可以是位置參數(shù)、命名參數(shù)或者兼而有之。
format 函數(shù)可以接受不限個(gè)參數(shù),位置可以不按順序。
語(yǔ)法:format(value, format_spec)
# 位置參數(shù) '{}:您{}購(gòu)買的{}到了!請(qǐng)下樓取快遞。'.format('快遞小哥','淘寶','快遞') '快遞小哥:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞。'#給批量客戶發(fā)短息 n_list=['馬云','馬化騰','麻子','小紅','李彥宏','二狗子'] for name in n_list: print('{0}:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞!'.format(name)) 馬云:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 馬化騰:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 麻子:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 小紅:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 李彥宏:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 二狗子:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞!#名字進(jìn)行填充 for n in n_list: print('{0}:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞!'.format(n.center(3,'*')))*馬云:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 馬化騰:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! *麻子:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! *小紅:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 李彥宏:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞! 二狗子:您淘寶購(gòu)買的快遞到了!請(qǐng)下樓取快遞!'{0}, {1} and {2}'.format('gao','fu','shuai') 'gao,?fu?and?shuai' x=3 y=5 '{0}+{1}={2}'.format(x,y,x+y) # 命名參數(shù) '{name1}, {name2} and {name3}'.format(name1='gao', name2='fu', name3='shuai') 'gao, fu and shuai' # 混合位置參數(shù)、命名參數(shù) '{name1}, {0} and {name3}'.format("shuai", name1='fu', name3='gao') 'fu,?shuai?and?gao'#for循環(huán)進(jìn)行批量處理 ["vec_{0}".format(i) for i in range(0,5)] ['vec_0', 'vec_1', 'vec_2', 'vec_3', 'vec_4']['f_{}'.format(r) for r in list('abcde')]['f_a', 'f_b', 'f_c', 'f_d', 'f_e']?
bytes()
描述:將一個(gè)字符串轉(zhuǎn)換成字節(jié)類型
語(yǔ)法:class bytes([source[, encoding[, errors]]])
參數(shù):
如果 source 為整數(shù),則返回一個(gè)長(zhǎng)度為 source 的初始化數(shù)組;
如果 source 為字符串,則按照指定的 encoding 將字符串轉(zhuǎn)換為字節(jié)序列;
如果 source 為可迭代類型,則元素必須為[0 ,255] 中的整數(shù);
如果 source 為與 buffer 接口一致的對(duì)象,則此對(duì)象也可以被用于初始化 bytearray。
如果沒有輸入任何參數(shù),默認(rèn)就是初始化數(shù)組為0個(gè)元素。
bytearray()
描述:返回一個(gè)新字節(jié)數(shù)組. 這個(gè)數(shù)字的元素是可變的, 并且每個(gè)元素的值得范圍是[0,256)
語(yǔ)法:class bytearray([source[, encoding[, errors]]])
參數(shù):
如果 source 為整數(shù),則返回一個(gè)長(zhǎng)度為 source 的初始化數(shù)組;
如果 source 為字符串,則按照指定的 encoding 將字符串轉(zhuǎn)換為字節(jié)序列;
如果 source 為可迭代類型,則元素必須為[0 ,255] 中的整數(shù);
如果 source 為與 buffer 接口一致的對(duì)象,則此對(duì)象也可以被用于初始化 bytearray。
如果沒有輸入任何參數(shù),默認(rèn)就是初始化數(shù)組為0個(gè)元素。
?
ord()
描述:查看某個(gè)ascii對(duì)應(yīng)的十進(jìn)制數(shù)
語(yǔ)法:ord(c)
參數(shù):c -- 字符。
ord('A') 65 ord('~') 126?
chr()
描述:chr() 用一個(gè)范圍在 range(256)內(nèi)的(就是0~255)整數(shù)作參數(shù),返回一個(gè)對(duì)應(yīng)的字符。
語(yǔ)法:chr(i)
參數(shù):i -- 可以是10進(jìn)制也可以是16進(jìn)制的形式的數(shù)字。
查看十進(jìn)制整數(shù)對(duì)應(yīng)的ASCII字符 chr(65) 'A' 可以參考4案例中的表?
ascii()
描述:ascii() 函數(shù)返回任何對(duì)象(字符串,元組,列表等)的可讀版本。
ascii() 函數(shù)會(huì)將所有非 ascii 字符替換為轉(zhuǎn)義字符:
? 將替換為 \xe5。
語(yǔ)法:ascii(object)
參數(shù):object--對(duì)象,可以是元組、列表、字典、字符串、set()創(chuàng)建的集合。
ascii('中國(guó)') "'\\u4e2d\\u56fd'"ascii('新冠肺炎') "'\\u65b0\\u51a0\\u80ba\\uascii("My name is St?le") "'My name is St\\xe5le'"print(ascii((1,2))) #元組 (1, 2) print(type(ascii((1,2)))) <class 'str'>print(ascii([1,2])) #列表 [1, 2] print(type(ascii([1,2]))) <class 'str'>print(ascii('?')) #字符串,非 ASCII字符,轉(zhuǎn)義 '\uff1f' print(type(ascii("?"))) <class 'str'>print(ascii({1:2,'name':5})) #字典 {1: 2, 'name': 5} print(type(ascii({1:2,'name':5}))) <class 'str'>ASCII碼表具體如下所示(節(jié)選)
Bin (二進(jìn)制) | Oct (八進(jìn)制) | Dec (十進(jìn)制) | Hex (十六進(jìn)制) | 縮寫/字符 | 解釋 |
0000 0000 | 00 | 0 | 0x00 | NUL(null) | 空字符 |
0010 0001 | 041 | 33 | 0x21 | ! | 嘆號(hào) |
0010 0010 | 042 | 34 | 0x22 | " | 雙引號(hào) |
0010 1010 | 052 | 42 | 0x2A | * | 星號(hào) |
... | ... | ... | ... | ... | ... |
0111 1101 | 0175 | 125 | 0x7D | } | 閉花括號(hào) |
0111 1110 | 0176 | 126 | 0x7E | ~ | 波浪號(hào) |
0111 1111 | 0177 | 127 | 0x7F | DEL (delete) | 刪除 |
repr()
返回一個(gè)對(duì)象的string形式
?
03 數(shù)據(jù)結(jié)構(gòu)處理相關(guān)函數(shù)
len()
描述:len() 函數(shù)返回對(duì)象(字符、列表、元組等)長(zhǎng)度或項(xiàng)目個(gè)數(shù)。
語(yǔ)法:len(s)
參數(shù):s -- 對(duì)象。
#字典的長(zhǎng)度 dic = {'a':1,'b':3} len(dic) 2#字符串長(zhǎng)度 s='aasdf' len(s) 5#列表元素個(gè)數(shù) l = [1,2,3,4,5] len(l)?
sorted()?
描述:sorted()函數(shù)對(duì)所有可迭代的對(duì)象進(jìn)行排序操作。
語(yǔ)法:sorted(iterable, ?key=None, reverse=False)
參數(shù):
iterable--可迭代對(duì)象。
key--主要是用來進(jìn)行比較的元素,只有一個(gè)參數(shù),具體的函數(shù)的參數(shù)就是取自于可迭代對(duì)象中,指定可迭代對(duì)象中的一個(gè)元素來進(jìn)行排序。
reverse -- 排序規(guī)則,reverse=True降序 ,reverse = False升序(默認(rèn))。
sort 與 sorted 區(qū)別:
sort 是應(yīng)用在list 的方法,sorted可以對(duì)所有可迭代的對(duì)象進(jìn)行排序操作;list的sort 方法返回的是對(duì)已經(jīng)存在的列表進(jìn)行操作,無(wú)返回值,而內(nèi)建函數(shù)sorted方法返回的是一個(gè)新的 list,而不是在原來的基礎(chǔ)上進(jìn)行的操作。
?
reversed()
描述:reversed函數(shù)返回一個(gè)反轉(zhuǎn)的迭代器。
語(yǔ)法:reversed(seq)
參數(shù):seq -- 要轉(zhuǎn)換的序列,可以是 tuple, string, list 或 range。
#反轉(zhuǎn)列表 rev = reversed([1,4,2,3,1]) list(rev) [1, 3, 2, 4, 1]#反轉(zhuǎn)字符串 rev = reversed('我愛中國(guó)') list(rev) ['國(guó)', '中', '愛', '我']''.join(rev) '國(guó)中愛我's = '我的世界開始下雪' ''.join(reversed(s)) '雪下始開界世的我'?
slice()
描述:slice()?函數(shù)實(shí)現(xiàn)切片對(duì)象,主要用在切片操作函數(shù)里的參數(shù)傳遞。返回一個(gè)表示由 range(start, stop, step) 所指定索引集的 slice對(duì)象
語(yǔ)法:
class slice(stop)
class slice(start, stop[, step])
參數(shù):
start -- 起始位置
stop -- 結(jié)束位置
step -- 間距
?
enumerate()
描述:enumerate() 函數(shù)用于將一個(gè)可遍歷的數(shù)據(jù)對(duì)象(如列表、元組或字符串)組合為一個(gè)索引序列,同時(shí)列出數(shù)據(jù)和數(shù)據(jù)下標(biāo),一般用在for循環(huán)當(dāng)中。返回一個(gè)可以枚舉的對(duì)象,該對(duì)象的next()方法將返回一個(gè)元組。enumerate在字典上是枚舉、列舉的意思。
語(yǔ)法:enumerate(sequence, [start=0])
參數(shù):sequence -- 一個(gè)序列、迭代器或其他支持迭代對(duì)象。
? ? ? ? ? start -- 下標(biāo)起始位置。
L = ['Spring', 'Summer', 'Fall', 'Winter'] enumerate(L) <enumerate at 0x226e1ee1138>#生成的額迭代器,無(wú)法直接查看 list(enumerate(L))#列表形式,可以看到內(nèi)部結(jié)構(gòu),默認(rèn)下標(biāo)從0開始 [(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')]list(enumerate(L, start=1)) #下標(biāo)從 1 開始 [(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')]for i,v in enumerate(L): print(i,v) 0 Spring 1 Summer 2 Fall 3 Winterfor i,v in enumerate(L,1):print(i,v) 1 Spring 2 Summer 3 Fall 4 Winters = ["a","b","c"]for i ,v in enumerate(s,2): print(i,v) 2 a 3 b 4 c普通的 for 循環(huán) i = 0 seq = ['one', 'two', 'three'] for element in seq: print (i, seq[i])i+= 1 0 one 1 two 2 three在看一個(gè)普通循環(huán)的對(duì)比案例 for 循環(huán)使用 enumerateseq = ['one', 'two', 'three'] for i, element in enumerate(seq):print?(i,?element) 0 one 1 two 2 threeseq = ['one', 'two', 'three'] for i, element in enumerate(seq,2): print (i, element) 2 one 3 two 4 threeall()
描述:接受一個(gè)迭代器,如果迭代器(元組或列表)的所有元素都為真,那么返回True,否則返回False,元素除了是0、空、None、False外都算 True。注意:空元組、空列表返回值為True,這里要特別注意。
語(yǔ)法:all(iterable)
參數(shù):iterable -- 元組或列表
案例:
all([1,0,3,6]) Falseall([1,9,3,6]) Trueall(['a', 'b', '', 'd']) False all([]) #空列表為真 Trueall(()) #空元組為真 Trueany() 描述:接受一個(gè)迭代器,如果迭代器里有一個(gè)元素為真,那么返回True,否則返回False,元素除了是 0、空、None、False 外都算 True。 語(yǔ)法:any(iterable) 參數(shù):iterable -- 元組或列表 案例: any([0,0,0,[]]) Falseany([0,0,1]) Trueany((0, '', False)) Falseany([]) # 空列表 Falseany(()) # 空元組 Falsezip()
描述:zip()?函數(shù)用于將可迭代的對(duì)象作為參數(shù),將對(duì)象中對(duì)應(yīng)的元素打包成一個(gè)個(gè)元組,然后返回由這些元組組成的對(duì)象,這樣做的好處是節(jié)約了不少的內(nèi)存。我們可以使用 list() 轉(zhuǎn)換來輸出列表。,如果各個(gè)迭代器的元素個(gè)數(shù)不一致,則返回列表長(zhǎng)度與最短的對(duì)象相同,利用?*?號(hào)操作符,可以將元組解壓為列表。
語(yǔ)法:zip([iterable,...])
參數(shù):iterable 一個(gè)或多個(gè)迭代器
創(chuàng)建一個(gè)聚合了來自每個(gè)可迭代對(duì)象中的元素的迭代器: x = [3,2,1] y = [4,5,6] list(zip(y,x)) [(4, 3), (5, 2), (6, 1)] #搭配for循環(huán),數(shù)字與字符串組合 a = range(5) b = list('abcde') [str(y)+str(x) for x,y in zip(a,b)] ['a0', 'b1', 'c2', 'd3', 'e4'] #數(shù)數(shù)相乘 list1 = [2,3,4] list2 = [5,6,7] for x,y in zip(list1,list2): print(x,'*',y,'--',x*y) 2 * 5 -- 10 3 * 6 -- 18 4 * 7 -- 28 #元素個(gè)數(shù)與最短的列表一致 list(zip(x,b))[(3, 'a'), (2, 'b'), (1, 'c')]s #與 zip 相反,zip(* ) 可理解為解壓,返回二維矩陣式 a1, a2 = zip(*zip(a,b)) a1 (0, 1, 2, 3, 4) a2 ('a',?'b',?'c',?'d','e')filter()
描述:filter()?函數(shù)用于過濾序列,過濾掉不符合條件的元素,返回由符合條件元素組成的新列表。該接收兩個(gè)參數(shù),第一個(gè)為函數(shù),第二個(gè)為序列,序列的每個(gè)元素作為參數(shù)傳遞給函數(shù)進(jìn)行判斷,然后返回 True 或 False,最后將返回 True 的元素放到新列表中。
語(yǔ)法:filter(function, iterable)
參數(shù):
function -- 判斷函數(shù)。
iterable -- 可迭代對(duì)象。
?
map()
描述:map()?會(huì)根據(jù)提供的函數(shù)對(duì)指定序列做映射。返回一個(gè)將 function 應(yīng)用于 iterable 中每一項(xiàng)并輸出其結(jié)果的迭代器
語(yǔ)法:map(function, iterable, ...)
參數(shù):
function -- 函數(shù)
iterable -- 一個(gè)或多個(gè)序列
?
三、和作用域相關(guān)
locals()
描述:locals()?函數(shù)會(huì)以字典類型返回當(dāng)前位置的全部局部變量。對(duì)于函數(shù), 方法, lambda 函式, 類, 以及實(shí)現(xiàn)了 __call__ 方法的類實(shí)例, 它都返回 True。
語(yǔ)法:locals()
?
globals()
描述:?函數(shù)會(huì)以字典類型返回當(dāng)前位置的全部全局變量。
語(yǔ)法:globals()
參數(shù):無(wú)
a='runoob' print(globals())? #globals 函數(shù)返回一個(gè)全局變量的字典,包括所有導(dǎo)入的變量。?
四、迭代器生成器
range()
描述:range() 函數(shù)可創(chuàng)建一個(gè)整數(shù)列表,一般用在 for 循環(huán)中。
語(yǔ)法:range(start, stop[, step])
參數(shù):
start: 計(jì)數(shù)從 start 開始。默認(rèn)是從 0 開始。例如range(5)等價(jià)于range(0, 5);
stop: 計(jì)數(shù)到 stop 結(jié)束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]沒有5
step:步長(zhǎng),默認(rèn)為1。例如:range(0,5)等價(jià)于 range(0, 5, 1)
next()
描述:next()?返回迭代器的下一個(gè)項(xiàng)目。next() 函數(shù)要和生成迭代器的iter() 函數(shù)一起使用。
語(yǔ)法:next(iterator[, default])
參數(shù):
iterator -- 可迭代對(duì)象
default -- 可選,用于設(shè)置在沒有下一個(gè)元素時(shí)返回該默認(rèn)值,如果不設(shè)置,又沒有下一個(gè)元素則會(huì)觸發(fā)StopIteration異常。
不加默認(rèn)值的情況,最后會(huì)報(bào)錯(cuò)StopIteration
it = iter([5,3,4,1]) next(it) 5 next(it) 3 next(it) 4 next(it) 1 next(it) Traceback (most recent call last):File "<ipython-input-392-bc1ab118995a>", line 1, in <module>next(it) StopIteration加默認(rèn)值的情況,最后迭代完了,會(huì)返回默認(rèn)值
it = iter([0,1,2,3,4]) next(it,'結(jié)束了') 0 next(it,'結(jié)束了') 1 next(it,'結(jié)束了') 2 next(it,'結(jié)束了') 3 next(it,'結(jié)束了') 4 next(it,'結(jié)束了') '結(jié)束了'?
iter()
描述:返回一個(gè)?iterator?對(duì)象
語(yǔ)法:iter(object[,?sentinel])
參數(shù):
object -- 支持迭代的集合對(duì)象。
sentinel -- 如果傳遞了第二個(gè)參數(shù),則參數(shù) object 必須是一個(gè)可調(diào)用的對(duì)象(如,函數(shù)),此時(shí),iter 創(chuàng)建了一個(gè)迭代器對(duì)象,每次調(diào)用這個(gè)迭代器對(duì)象的__next__()方法時(shí),都會(huì)調(diào)用 object。
?
五、字符串類型代碼的執(zhí)行
eval()
描述:將字符串str 當(dāng)成有效的表達(dá)式來求值并返回計(jì)算結(jié)果取出字符串中內(nèi)容
語(yǔ)法:eval(expression[, globals[, locals]])
參數(shù):
expression -- 表達(dá)式。
globals -- 變量作用域,全局命名空間,如果被提供,則必須是一個(gè)字典對(duì)象。
locals -- 變量作用域,局部命名空間,如果被提供,可以是任何映射對(duì)象。
?
exec()
描述:執(zhí)行儲(chǔ)存在字符串或文件中的Python語(yǔ)句,相比于eval,exec可以執(zhí)行更復(fù)雜的Python代碼。
語(yǔ)法:exec(object, globals, locals)
參數(shù):
object-- 要執(zhí)行的表達(dá)式。
globals -- 可選。包含全局參數(shù)的字典。
locals -- 可選。包含局部參數(shù)的字典。
?
compile()
描述:compile() 將?source?編譯成代碼或 AST 對(duì)象,將字符串類型的代碼編碼, 代碼對(duì)象能夠通過exec語(yǔ)句來執(zhí)行或者eval()進(jìn)行求值
語(yǔ)法:compile(source, filename, mode[, flags[, dont_inherit]])
參數(shù):
source -- 字符串或者AST(Abstract Syntax Trees)對(duì)象。。
filename -- 代碼文件名稱,如果不是從文件讀取代碼則傳遞一些可辨認(rèn)的值。
mode -- 指定編譯代碼的種類。可以指定為 exec, eval, single。
flags -- 變量作用域,局部命名空間,如果被提供,可以是任何映射對(duì)象。。
flags和dont_inherit是用來控制編譯源碼時(shí)的標(biāo)志
六、輸入輸出
print()
描述:print()?方法用于打印輸出,最常見的一個(gè)函數(shù)。在 Python3.3 版增加了 flush 關(guān)鍵字參數(shù)。print 在 Python3.x 是一個(gè)函數(shù),但在 Python2.x 版本不是一個(gè)函數(shù),只是一個(gè)關(guān)鍵字。
語(yǔ)法:print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)
參數(shù):
objects -- 復(fù)數(shù),表示可以一次輸出多個(gè)對(duì)象。輸出多個(gè)對(duì)象時(shí),需要用 , 分隔。
sep -- 用來間隔多個(gè)對(duì)象,默認(rèn)值是一個(gè)空格。
end -- 用來設(shè)定以什么結(jié)尾。默認(rèn)值是換行符 \n,我們可以換成其他字符串。
file -- 要寫入的文件對(duì)象。
flush -- 輸出是否被緩存通常決定于 file,但如果 flush 關(guān)鍵字參數(shù)為 True,流會(huì)被強(qiáng)制刷新。
?
input()
描述:Python3.x 中 input() 函數(shù)接受一個(gè)標(biāo)準(zhǔn)輸入數(shù)據(jù),返回為 string 類型。獲取用戶輸入內(nèi)容
語(yǔ)法:input([prompt])
參數(shù):prompt:--提示信息
a = input("input:") input:1234 print(a) 123?
七、內(nèi)存相關(guān)
hash()
描述:返回該對(duì)象的哈希值(如果它有的話)。哈希值是整數(shù)。它們?cè)谧值洳檎以貢r(shí)用來快速比較字典的鍵。相同大小的數(shù)字變量有相同的哈希值(即使它們類型不同,如 1 和 1.0),hash表.用空間換的時(shí)間 比較耗費(fèi)內(nèi)存,hash() 函數(shù)可以應(yīng)用于數(shù)字、字符串和對(duì)象,不能直接應(yīng)用于 list、set、dictionary。
語(yǔ)法:hash(object)
參數(shù):object -- 對(duì)象
案例:
在hash()對(duì)對(duì)象使用時(shí),所得的結(jié)果不僅和對(duì)象的內(nèi)容有關(guān),還和對(duì)象的id(),也就是內(nèi)存地址有關(guān)。 class Test:def __init__(self, i):self.i = i for i in range(10):t = Test(1)print(hash(t), id(t)) -9223371853633304640 2931543538696 -9223371853633350840 2931542799496 -9223371853633350832 2931542799624 -9223371853633350756 2931542800840 -9223371853520958964 2933341069512 -9223371853633350668 2931542802248 -9223371853633350796 2931542800200 -9223371853633350748 2931542800968 -9223371853633350856 2931542799240 -9223371853633350880 2931542798856hash() 函數(shù)的用途:hash() 函數(shù)的對(duì)象字符不管有多長(zhǎng),返回的hash值都是固定長(zhǎng)度的,也用于校驗(yàn)程序在傳輸過程中是否被第三方(木馬)修改,如果程序(字符)在傳輸過程中被修改hash值即發(fā)生變化,如果沒有被修改,則hash值和原始的hash值吻合,只要驗(yàn)證hash值是否匹配即可驗(yàn)證程序是否帶木馬(病毒)。
name1 = '正常程序代碼' name2 = '正常程序代碼帶病毒' print(hash(name1)) -3048480827538126659 print(hash(name2)) -9065726187242961328?
memoryview()
描述:memoryview()?函數(shù)返回給定參數(shù)的內(nèi)存查看對(duì)象(Momory view)。返回由給定實(shí)參創(chuàng)建的“內(nèi)存視圖”對(duì)象, Python 代碼訪問一個(gè)對(duì)象的內(nèi)部數(shù)據(jù),只要該對(duì)象支持緩沖區(qū)協(xié)議 而無(wú)需進(jìn)行拷貝
語(yǔ)法:memoryview(obj)
參數(shù):obj -- 對(duì)象
v = memoryview(bytearray("abcefg", 'utf-8')) v[1] 98 v[-1] 98v[1:4] <memory at 0x0000028B68E26AC8> v[1:4].tobytes() b'bce'?
八、文件讀寫
open()
描述:open()函數(shù)用于打開一個(gè)文件,創(chuàng)建一個(gè)file對(duì)象,相關(guān)的方法才可以調(diào)用它進(jìn)行讀寫。所以open()讀取文件分為兩步。
語(yǔ)法:open(name[, mode[, buffering]])
參數(shù):
name : 一個(gè)包含了你要訪問的文件名稱的字符串值。
mode : mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個(gè)參數(shù)是非強(qiáng)制的,默認(rèn)文件訪問模式為只讀(r)。
buffering : 如果 buffering 的值被設(shè)為 0,就不會(huì)有寄存。如果 buffering 的值取 1,訪問文件時(shí)會(huì)寄存行。如果將 buffering 的值設(shè)為大于1的整數(shù),表明了這就是的寄存區(qū)的緩沖大小。如果取負(fù)值,寄存區(qū)的緩沖大小則為系統(tǒng)默認(rèn)。
打開文件的模式:
r: 打開一個(gè)文件用于只讀,文件的指針將會(huì)放在文件的開頭,這是默認(rèn)模式。
w:打開一個(gè)文件用于寫入,如果文件存在則打開文件,并從開頭開始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。
a:打開一個(gè)文件用于追加,如果文件已存在,文件指針將會(huì)放在文件的結(jié)尾,如果文件不存在,創(chuàng)建新文件進(jìn)行寫入。
?
r+:打開一個(gè)文件用于讀寫,文件指針將會(huì)放在文件的開頭。
w+:打開一個(gè)文件用于讀寫。如果該文件已存在,刪除原有內(nèi)容并從開頭開始編輯;如果該文件不存在,創(chuàng)建新文件。
a+:打開一個(gè)文件用于讀寫。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾,如果該文件不存在,創(chuàng)建新文件用于讀寫。
?
rb:以二進(jìn)制格式打開一個(gè)文件用于只讀。文件指針將會(huì)放在文件的開頭。這是默認(rèn)模式。
rb+:以二進(jìn)制格式打開一個(gè)文件用于讀寫。文件指針將會(huì)放在文件的開頭。
wb:以二進(jìn)制格式打開一個(gè)文件只用于寫入。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。
wb+:以二進(jìn)制格式打開一個(gè)文件用于讀寫。如果該文件已存在則打開文件,并從開頭開始編輯,即原有內(nèi)容會(huì)被刪除。如果該文件不存在,創(chuàng)建新文件。
ab:以二進(jìn)制格式打開一個(gè)文件用于追加。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。也就是說,新的內(nèi)容將會(huì)被寫入到已有內(nèi)容之后。如果該文件不存在,創(chuàng)建新文件進(jìn)行寫入。
ab+:以二進(jìn)制格式打開一個(gè)文件用于追加。如果該文件已存在,文件指針將會(huì)放在文件的結(jié)尾。如果該文件不存在,創(chuàng)建新文件用于讀寫。
注意:當(dāng)讀取音視頻、圖片等二進(jìn)制文件時(shí),需要采用二進(jìn)制的讀取方法。
?
file對(duì)象方法
file.read([size]):size 未指定則返回整個(gè)文件,如果文件大小>2 倍內(nèi)存則有問題,f.read()讀到文件尾時(shí)返回""(空字串)。
file.readline():返回一行。
file.readlines([size])?:返回包含size行的列表, size 未指定則返回全部行。
for line in file:?print(line):通過迭代器訪問。
file.write():如果要寫入字符串以外的數(shù)據(jù),先將他轉(zhuǎn)換為字符串。
file.tell():返回一個(gè)整數(shù),表示當(dāng)前文件指針的位置(就是到文件頭的比特?cái)?shù))。
file.seek(偏移量,[起始位置]):用來移動(dòng)文件指針。偏移量: 單位為比特,可正可負(fù);起始位置: 0 - 文件頭, 默認(rèn)值; 1 - 當(dāng)前位置; 2 - 文件尾
file.close():關(guān)閉文件
file = open('test.txt',encoding='utf-8') #打開文件 file.read()#直接顯示文件所有內(nèi)容 file.readline#顯示第一行 file.close() #關(guān)閉文件test.txt存儲(chǔ)的的內(nèi)容如下
hello python i love you?
read()方法
file = open('test.txt') file.read() 'hello\npython\ni\nlove you'readline()方法
readlines()方法
逐行讀取
?
九、模塊相關(guān)
__ import__()
描述:該函數(shù)會(huì)導(dǎo)入 name 模塊,有可能使用給定的 globals 和 locals 來確定如何在包的上下文中解讀名稱。fromlist 給出了應(yīng)該從由 name 指定的模塊導(dǎo)入對(duì)象或子模塊的名稱。標(biāo)準(zhǔn)實(shí)現(xiàn)完全不使用其 locals 參數(shù),而僅使用 globals 參數(shù)來確定 import 語(yǔ)句的包上下文。level 指定是使用絕對(duì)還是相對(duì)導(dǎo)入。?0?(默認(rèn)值) 意味著僅執(zhí)行絕對(duì)導(dǎo)入。
語(yǔ)法:__import__(name,?globals=None,?locals=None,?fromlist=(),?level=0)
參數(shù):object -- 對(duì)象
語(yǔ)句 import spam的結(jié)果將為與以下代碼作用相同的字節(jié)碼:spam = __import__('spam.ham', globals(), locals(), [], 0)?
十、獲取幫助
help()
描述:返回對(duì)象的幫助文檔
語(yǔ)法:help(object)
參數(shù):object -- 對(duì)象
help('sys') # 查看sys模塊的幫助 ??可以看到文檔的網(wǎng)址:https://docs.python.org/3.7/library/sys
查看str數(shù)據(jù)類型的幫助
help('str')可以看到,字符串相關(guān)的所有方法用法介紹? ? ? ?
a = [1,2,3] help(a) # 查看列表list幫助信息 help(a.append)# 顯示list的append方法的幫助十一、對(duì)象調(diào)用
callable()
描述:callable()?函數(shù)用于檢查一個(gè)對(duì)象是否是可調(diào)用的。如果返回 True,object 仍然可能調(diào)用失敗;但如果返回 False,調(diào)用對(duì)象object絕對(duì)不會(huì)成功。對(duì)于函數(shù)、方法、lambda 函式、 類以及實(shí)現(xiàn)了?__call__?方法的類實(shí)例, 它都返回True。
這個(gè)函數(shù)一開始在 Python 3.0 被移除了,但在 Python 3.2 被重新加入。
語(yǔ)法:callable(object)
參數(shù):object -- 對(duì)象
#檢查一個(gè)數(shù)字 callable(0) False#創(chuàng)建一個(gè)函數(shù) def add(x,y):return x+y callable(add) True#創(chuàng)建一個(gè)帶有__call__方法的類 class Dogs:def __call__(self):return 0 callable(Dogs) True?
十二、內(nèi)置屬性
dir()
描述:dir()?查看對(duì)象的內(nèi)置屬性, 訪問的是對(duì)象中的__dir__()方法,函數(shù)不帶參數(shù)時(shí),返回當(dāng)前范圍內(nèi)的變量、方法和定義的類型列表;帶參數(shù)時(shí),返回參數(shù)的屬性、方法列表。如果參數(shù)包含方法__dir__(),該方法將被調(diào)用,如果參數(shù)不包含__dir__(),該方法將最大限度地收集參數(shù)信息。
語(yǔ)法:dir(object)
參數(shù):object 對(duì)象、變量、類型。
#獲得當(dāng)前模塊的屬性列表 dir() ['In','Out', 'exit', 'get_ipython', 'quit']#查看列表的方法,使用dir([ ])或者dir(list())#查看列表的方法 print(dir(list())) ['__add__', ... 'copy', 'count', 'extend', 'index', 'insert', 'pop',?'reverse',?'sort','remove']dir()訪問的是對(duì)象中的__dir__()方法,因此下面的調(diào)用也能得到相同的結(jié)果:
list().__dir__() [__repr__',,?...?'copy',?'count',?'extend',?'index',?'insert',?'pop',?'remove',?'rever']print(dir(str))、print(dir(list))、print(dir(dict))、分別獲取各個(gè)數(shù)據(jù)類型的方法,不帶參數(shù)時(shí)返回當(dāng)前范圍內(nèi)的變量,方法和定義的類型列表;帶參數(shù)時(shí)返回參數(shù)的屬性,方法列表。
?
hasattr()
描述:函數(shù)用于判斷對(duì)象是否包含對(duì)應(yīng)的屬性。
語(yǔ)法:hasattr(object, name)
參數(shù):
object -- 對(duì)象。
name -- 字符串,屬性名。
總結(jié)
以上是生活随笔為你收集整理的【Python基础】Python初学者必须吃透这69个内置函数!的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【数据竞赛】2020 Kaggle 10
- 下一篇: 手机qq浏览器怎么设置上下翻页按钮 手机