12.0、python內(nèi)置函數(shù)和匿名函數(shù)

內(nèi)置函數(shù)和匿名函數(shù)

楔子

在講新知識(shí)之前,我們先來(lái)復(fù)習(xí)復(fù)習(xí)函數(shù)的基礎(chǔ)知識(shí)。

問:函數(shù)怎么調(diào)用?

函數(shù)名()

如果你們這么說。。。那你們就對(duì)了!好了記住這個(gè)事兒別給忘記了,咱們繼續(xù)談下一話題。。。

來(lái)你們?cè)谧约旱沫h(huán)境里打印一下自己的名字。

你們是怎么打的呀?

是不是print('xxx'),好了,現(xiàn)在你們結(jié)合我剛剛說的函數(shù)的調(diào)用方法,你有沒有什么發(fā)現(xiàn)?

我們就猜,print有沒有可能是一個(gè)函數(shù)?

但是沒有人實(shí)現(xiàn)它啊。。。它怎么就能用了呢?

早在我們“初識(shí)函數(shù)”的時(shí)候是不是就是用len()引出的?

那現(xiàn)在我們也知道len()也是一個(gè)函數(shù),也沒人實(shí)現(xiàn),它好像就自己能用了。。。

之前老師給你講你可以這樣用你就用了,那你有沒有想過像這樣直接拿來(lái)就能用的函數(shù)到底有多少?

內(nèi)置函數(shù)

接下來(lái),我們就一起來(lái)看看python里的內(nèi)置函數(shù)。截止到python版本3.6.2,現(xiàn)在python一共為我們提供了68個(gè)內(nèi)置函數(shù)。它們就是python提供給你直接可以拿來(lái)使用的所有函數(shù)。這些函數(shù)有些我們已經(jīng)用過了,有些我們還沒用到過,還有一些是被封印了,必須等我們學(xué)了新知識(shí)才能解開封印的。那今天我們就一起來(lái)認(rèn)識(shí)一下python的內(nèi)置函數(shù)。這么多函數(shù),我們?cè)搹暮螌W(xué)起呢?

Built-in?Functions

abs()dict()help()min()setattr()

all()dir()hex()next()slice()

any()divmod()id()object()sorted()

ascii()enumerate()input()oct()staticmethod()

bin()eval()int()open()str()

bool()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()

delattr()hash()memoryview()set()

上面就是內(nèi)置函數(shù)的表,68個(gè)函數(shù)都在這兒了。這個(gè)表的順序是按照首字母的排列順序來(lái)的,你會(huì)發(fā)現(xiàn)都混亂的堆在一起。比如,oct和bin和hex都是做進(jìn)制換算的,但是卻被寫在了三個(gè)地方。。。這樣非常不利于大家歸納和學(xué)習(xí)。那我把這些函數(shù)分成了6大類。你看下面這張圖,你猜咱們今天會(huì)學(xué)哪幾大類呀??

我猜你們都猜對(duì)了。我們今天就要學(xué)習(xí)用粉紅色標(biāo)注出來(lái)的這四大塊——56個(gè)方法。還有12個(gè)方法欠著怎么辦呢?我們講完面向?qū)ο筮@剩下的12個(gè)會(huì)在兩周之內(nèi)陸續(xù)還給你們的,我保證(認(rèn)真臉)。那這樣,我們今天就主要關(guān)注我們要學(xué)習(xí)的這56個(gè)方法。

那要學(xué)的一共4塊,咱們從哪兒開始學(xué)起呢?

作用域相關(guān)


基于字典的形式獲取局部變量和全局變量

globals()——獲取全局變量的字典

locals()——獲取執(zhí)行本方法所在命名空間內(nèi)的局部變量的字典

其他


字符串類型代碼的執(zhí)行

輸入輸出相關(guān):

input() 輸入

s = input("請(qǐng)輸入內(nèi)容 : ")? #輸入的內(nèi)容賦值給s變量print(s)? #輸入什么打印什么。數(shù)據(jù)類型是str

print() 輸出

def print(self, *args, sep=' ', end='\n', file=None): # known special case of print? ? """

? ? print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False)

? ? file:? 默認(rèn)是輸出到屏幕,如果設(shè)置為文件句柄,輸出到文件

? ? sep:? 打印多個(gè)值之間的分隔符,默認(rèn)為空格

? ? end:? 每一次打印的結(jié)尾,默認(rèn)為換行符

? ? flush: 立即把內(nèi)容輸出到流文件,不作緩存

? ? """

f = open('tmp_file','w')print(123,456,sep=',',file = f,flush=True)

import timefor i in range(0,101,2):?

? ? time.sleep(0.1)

? ? char_num = i//2? ? ? #打印多少個(gè)'*'? ? per_str = '\r%s%% : %s\n' % (i, '*' * char_num) if i == 100 else '\r%s%% : %s'%(i,'*'*char_num)

? ? print(per_str,end='', flush=True)#小越越? : \r 可以把光標(biāo)移動(dòng)到行首但不換行


數(shù)據(jù)類型相關(guān):

type(o)?

返回變量o的數(shù)據(jù)類型


內(nèi)存相關(guān):

id(o) o是參數(shù)

返回一個(gè)變量的內(nèi)存地址

hash(o) o是參數(shù)

返回一個(gè)可hash變量的哈希值,不可hash的變量被hash之后會(huì)報(bào)錯(cuò)。

t = (1,2,3)

l = [1,2,3]print(hash(t))? #可hashprint(hash(l))? #會(huì)報(bào)錯(cuò)'''

結(jié)果:

TypeError: unhashable type: 'list'

'''

hash函數(shù)會(huì)根據(jù)一個(gè)內(nèi)部的算法對(duì)當(dāng)前可hash變量進(jìn)行處理,返回一個(gè)int數(shù)字。

*每一次執(zhí)行程序,內(nèi)容相同的變量hash值在這一次執(zhí)行過程中不會(huì)發(fā)生改變。


文件操作相關(guān)

open() ?

打開一個(gè)文件,返回一個(gè)文件操作符(文件句柄)

操作文件的模式有r,w,a,r+,w+,a+ 共6種,每一種方式都可以用二進(jìn)制的形式操作(rb,wb,ab,rb+,wb+,ab+)

可以用encoding指定編碼.


模塊操作相關(guān)

__import__

導(dǎo)入一個(gè)模塊

import time

os = __import__('os')print(os.path.abspath('.'))


幫助方法

在控制臺(tái)執(zhí)行help()進(jìn)入幫助模式??梢噪S意輸入變量或者變量的類型。輸入q退出

或者直接執(zhí)行help(o),o是參數(shù),查看和變量o有關(guān)的操作。。。


和調(diào)用相關(guān)

callable(o)

o是參數(shù),看這個(gè)變量是不是可調(diào)用。

如果o是一個(gè)函數(shù)名,就會(huì)返回True

def func():passprint(callable(func))? #參數(shù)是函數(shù)名,可調(diào)用,返回Trueprint(callable(123))? #參數(shù)是數(shù)字,不可調(diào)用,返回False


查看參數(shù)所屬類型的所有內(nèi)置方法

dir()

默認(rèn)查看全局空間內(nèi)的屬性,也接受一個(gè)參數(shù),查看這個(gè)參數(shù)內(nèi)的方法或變量

print(dir(list))? #查看列表的內(nèi)置方法print(dir(int))? #查看整數(shù)的內(nèi)置方法


和數(shù)字相關(guān)



數(shù)字——數(shù)據(jù)類型相關(guān):bool,int,float,complex

數(shù)字——進(jìn)制轉(zhuǎn)換相關(guān):bin,oct,hex

數(shù)字——數(shù)學(xué)運(yùn)算:abs,divmod,min,max,sum,round,pow


和數(shù)據(jù)結(jié)構(gòu)相關(guān)


序列——列表和元組相關(guān)的:list和tuple

序列——字符串相關(guān)的:str,format,bytes,bytearry,memoryview,ord,chr,ascii,repr

ret = bytearray('alex',encoding='utf-8')print(id(ret))print(ret[0])

ret[0] = 65print(ret)print(id(ret))

ret = memoryview(bytes('你好',encoding='utf-8'))print(len(ret))print(bytes(ret[:3]).decode('utf-8'))print(bytes(ret[3:]).decode('utf-8'))


序列:reversed,slice

l = (1,2,23,213,5612,342,43)print(l)print(list(reversed(l)))

l = (1,2,23,213,5612,342,43)

sli = slice(1,5,2)print(l[sli])


數(shù)據(jù)集合——字典和集合:dict,set,frozenset

數(shù)據(jù)集合:len,sorted,enumerate,all,any,zip,filter,map

匿名函數(shù)-lambda

匿名函數(shù):為了解決那些功能很簡(jiǎn)單的需求而設(shè)計(jì)的一句話函數(shù)

#這段代碼def calc(n):

? ? return n**nprint(calc(10))

#換成匿名函數(shù)calc = lambda n:n**nprint(calc(10))

上面是我們對(duì)calc這個(gè)匿名函數(shù)的分析,下面給出了一個(gè)關(guān)于匿名函數(shù)格式的說明

函數(shù)名 = lambda 參數(shù) :返回值#參數(shù)可以有多個(gè),用逗號(hào)隔開

#匿名函數(shù)不管邏輯多復(fù)雜,只能寫一行,且邏輯執(zhí)行結(jié)束后的內(nèi)容就是返回值

#返回值和正常的函數(shù)一樣可以是任意數(shù)據(jù)類型

我們可以看出,匿名函數(shù)并不是真的不能有名字。

匿名函數(shù)的調(diào)用和正常的調(diào)用也沒有什么分別。 就是 函數(shù)名(參數(shù)) 就可以了~~~

練一練:

請(qǐng)把以下函數(shù)變成匿名函數(shù)def add(x,y):

? ? return x+y


上面是匿名函數(shù)的函數(shù)用法。除此之外,匿名函數(shù)也不是浪得虛名,它真的可以匿名。在和其他功能函數(shù)合作的時(shí)候

l=[3,2,100,999,213,1111,31121,333]print(max(l))

dic={'k1':10,'k2':100,'k3':30}print(max(dic))print(dic[max(dic,key=lambda k:dic[k])])

res = map(lambda x:x**2,[1,5,7,4,8])for i in res:

? ? print(i)

輸出

1

25

49

16

64

res = filter(lambda x:x>10,[5,8,11,9,15])for i in res:

? ? print(i)

輸出

11

15

面試題練一練

1.下面程序的輸出結(jié)果是:

d = lambda p:p*2

t = lambda p:p*3

x = 2

x = d(x)

x = t(x)

x = d(x)print(x)

2.現(xiàn)有兩元組(('a'),('b')),(('c'),('d')),請(qǐng)使用python中匿名函數(shù)生成列表[{'a':'c'},{'b':'d'}]

#答案一test = lambda t1,t2 :[{i:j} for i,j in zip(t1,t2)]print(test(t1,t2))#答案二print(list(map(lambda t:{t[0]:t[1]},zip(t1,t2))))#還可以這樣寫print([{i:j} for i,j in zip(t1,t2)])

3.以下代碼的輸出是什么?請(qǐng)給出答案并解釋。def multipliers():

? ? return [lambda x:i*x for i in range(4)]print([m(2) for m in multipliers()])

請(qǐng)修改multipliers的定義來(lái)產(chǎn)生期望的結(jié)果。


本章小結(jié)

說學(xué)習(xí)內(nèi)置函數(shù),不如說整理自己的知識(shí)體系。其實(shí)整理這些內(nèi)置函數(shù)的過程也是在整理自己的知識(shí)體系。

我們講課的時(shí)候會(huì)歸類:常用或者不常用,主要還是根據(jù)場(chǎng)景而言。

一個(gè)優(yōu)秀的程序員就應(yīng)該是在該用這個(gè)方法的時(shí)候信手拈來(lái),把每一個(gè)內(nèi)置的函數(shù)都用的恰到好處。

要想做到這一點(diǎn),至少要先了解,才能在需要的時(shí)候想起,進(jìn)而將它用在該用的地方。

但是在這里,我還是以自己的一點(diǎn)經(jīng)驗(yàn)之談,把幾個(gè)平時(shí)工作中相對(duì)更常用的方法推薦一下,請(qǐng)務(wù)必重點(diǎn)掌握:

其他:input,print,type,hash,open,import,dir

str類型代碼執(zhí)行:eval,exec

數(shù)字:bool,int,float,abs,divmod,min,max,sum,round,pow

序列——列表和元組相關(guān)的:list和tuple

序列——字符串相關(guān)的:str,bytes,repr

序列:reversed,slice

數(shù)據(jù)集合——字典和集合:dict,set,frozenset

數(shù)據(jù)集合:len,sorted,enumerate,zip,filter,map

參考文檔:

  https://docs.python.org/3/library/functions.html#object

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 安娜莎蜂漿紙 什么是蜂漿紙? 它就是一款集卸妝 深層清潔 潔面而且還很溫和的清潔類洗護(hù)產(chǎn)品!它還可以代替洗面...
    安娜莎護(hù)膚品閱讀 248評(píng)論 0 0
  • 一:獲得文檔對(duì)象 二:查詢和遍歷節(jié)點(diǎn) 三:創(chuàng)建元素并添加對(duì)應(yīng)節(jié)點(diǎn) 到此 文檔對(duì)象寫入已經(jīng)完成,目前改變后的文檔對(duì)象...
    di調(diào)的悲傷閱讀 308評(píng)論 0 0
  • 2017.12.15 提起睡眠,覺得最累的是做夢(mèng)。 帶過運(yùn)動(dòng)手環(huán),顯示即使我睡九到十個(gè)小時(shí),深度睡眠基本不足兩個(gè)小...
    花貓頭閱讀 419評(píng)論 0 1
  • 說是寂寞的秋的清愁, 說是遼遠(yuǎn)的海的相思。 假如有人問我的煩憂, 我不敢說出你的名字。 我不敢說出你的名字, 假如...
    簡(jiǎn)書茶館葉老板閱讀 1,099評(píng)論 3 14

友情鏈接更多精彩內(nèi)容