小編寫這篇文章的話,主要是給大家做出一個(gè)解答,解答一些Python常見問題,比如關(guān)于編程函數(shù)的一些問題,哪些函數(shù)編程是最受用的呢?下面就給大家詳細(xì)介紹一下。
合理的使用Python這門工具,能夠大大的提高其工作效率,起到事半功倍的作用。
1.Map函數(shù)
map函數(shù)可以使用另外一個(gè)函數(shù)轉(zhuǎn)換整個(gè)可迭代對(duì)象的函數(shù),包括將字符串轉(zhuǎn)換為數(shù)字、數(shù)字的四舍五入等等。
之所以使用map函數(shù)來完成這些事情可以節(jié)約內(nèi)存,使代碼的運(yùn)行速度提高,并且使用的代碼量比較少。
比如這里需要將一個(gè)字符串的數(shù)組轉(zhuǎn)換成數(shù)字的數(shù)組的形式。
使用傳統(tǒng)的方式來進(jìn)行解析的話,使用for循環(huán)的方式就需要好幾行的代碼才能完成。
strings=['1','2','3','4'] res=[] for str_ in strings: res.append(int(str_)) print(res) #[1,2,3,4]
使用map函數(shù)直接需要一行代碼就可以完成了。
strings=['5','6','7','8'] res_map=map(int,strings) print(list(res_map)) #[5,6,7,8]
使用map(int,strings),其中int是作為函數(shù)作為參數(shù)傳入的,而strings就是可以迭代的對(duì)象。
這里再使用一個(gè)我們自己創(chuàng)建的函數(shù)來轉(zhuǎn)換可序列化的數(shù)據(jù)。
初始化一個(gè)make_super函數(shù)用來將英文字符串轉(zhuǎn)換成'大寫'的字符串。
def make_super(text): res_text=text.upper() return res_text words=['python','java','scala'] words_res=list(map(make_super,words)) print(words_res) #['PYTHON','JAVA','SCALA']
使用map(make_super,words),其中make_super是作為函數(shù)傳入的,而words作為可序列化數(shù)據(jù)。
2.Lamdba函數(shù)
lambda函數(shù)用于創(chuàng)建匿名函數(shù),又被稱為lambda表達(dá)式。實(shí)際上它只是一個(gè)表達(dá)式的存在,如果在代碼編寫過程中需要實(shí)現(xiàn)簡(jiǎn)單的函數(shù)邏輯但是多帶帶寫一個(gè)函數(shù)又比較麻煩就可以使用lambda表達(dá)式只需要一行代碼就可以完成了。
比如需要實(shí)現(xiàn)一個(gè)簡(jiǎn)單的加法計(jì)算,使用基本的函數(shù)來實(shí)現(xiàn)需要?jiǎng)?chuàng)建一個(gè)add_1函數(shù)。
def add_1(a,b): return a+b print(add_1(5,2))
而使用lambda表達(dá)式,一行代碼就可以直接完成了,可以像下面這樣寫。
add_2=lambda a,b:a+b print(add_2(10,10))
lambda a,b:a+b表示a,b是作為參數(shù),a+b是作為函數(shù)的運(yùn)算邏輯被執(zhí)行。
3.Enumerate函數(shù)
enumerate函數(shù)一般用于可序列化數(shù)據(jù)的處理上面,而python中的可序列化數(shù)據(jù)又比較多,重要性就可想而知了。
可以使用該函數(shù)直接遍歷出一個(gè)可序列化數(shù)據(jù)的下標(biāo)索引以及對(duì)應(yīng)的數(shù)據(jù)。
使用一個(gè)列表數(shù)據(jù)來進(jìn)行舉例說明。
words=['java','python','scala']
使用enumerate函數(shù)來執(zhí)行一下整個(gè)遍歷,最終返回一個(gè)新的列表。
for index,data in enumerate(words): print(f'當(dāng)前索引:{index},當(dāng)前數(shù)據(jù):{data}') #當(dāng)前索引:0,當(dāng)前數(shù)據(jù):java #當(dāng)前索引:1,當(dāng)前數(shù)據(jù):python #當(dāng)前索引:2,當(dāng)前數(shù)據(jù):scala
看到返回的結(jié)果中包含了索引、數(shù)據(jù),這樣便于數(shù)據(jù)的組織和統(tǒng)計(jì),因此,將該函數(shù)也列為比較常用的函數(shù)之一。
4.Reduce函數(shù)
reduce函數(shù)通常用于計(jì)算整個(gè)列表的邏輯運(yùn)算,也就是將一個(gè)函數(shù)的運(yùn)算可以添加到這個(gè)列表的每個(gè)元素上面。
''' reduce(function,iterable[,initializer]) '''
比如需要計(jì)算一個(gè)列表中每個(gè)元素之間的相乘的結(jié)果,則可以這樣寫。
from functools import reduce list_=[10,20,30,40] print(reduce(lambda a,b:a*b,list_))
這里由于函數(shù)的邏輯運(yùn)算比較簡(jiǎn)單,所以使用了lambda表達(dá)式表示兩個(gè)元素相乘。
最終再使用reduce函數(shù),它的效果相當(dāng)于10*20*30*40,結(jié)果就是240000,和我們預(yù)想得到的計(jì)算結(jié)果是一致的。
5.Filter函數(shù)
filter函數(shù),從字面意思就可以看出它是過濾的意思,使用該函數(shù)可以有效的過濾掉不需要的列表中的數(shù)據(jù)元素。
''' filter(function,iterable) '''
在邏輯處理中,同樣是需要一個(gè)處理函數(shù)和一個(gè)可序列化的數(shù)據(jù)。
nums=[1,2,3,4,5,6,7,8,9,20] nums_new=filter(lambda m:m%2==0,nums) print(list(nums_new)) #[2,4,6,8,20]
這里我們成功過濾掉了所有的奇數(shù)數(shù)據(jù)元素,最終只留下了偶數(shù)元素。
6.Zip函數(shù)
zip函數(shù)在多個(gè)列表的組裝過程中用到非常的多,可以同時(shí)遍歷多個(gè)列表并將相同位置的元素組合成一個(gè)元祖。
list_res=[] for n in zip([1,2,3,4,5],['python','java','scala','c++','C#']): list_res.append(n) print(list_res) #[(1,'python'),(2,'java'),(3,'scala'),(4,'c++'),(5,'C#')]
使用zip函數(shù)時(shí),像這樣的數(shù)據(jù)組合就可以輕松的實(shí)現(xiàn)。
通過觀察上述的這些操作發(fā)現(xiàn)基本上都是對(duì)可序列化的數(shù)據(jù)的相關(guān)操作,因?yàn)樵趐ython的編碼過程中大多數(shù)的數(shù)據(jù)處理相關(guān)的操作都是基于可序列化的數(shù)據(jù)的。
綜上所述,關(guān)于Python編程受歡迎的內(nèi)置函數(shù)就為大家介紹到這里了。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/128000.html
摘要:使用或機(jī)器語言的外部功能包處理時(shí)間敏感任務(wù),可以有效提高應(yīng)用的運(yùn)行效率。關(guān)鍵在于,優(yōu)化循環(huán)方案是提高應(yīng)用程序運(yùn)行速度的上佳選擇。此外,關(guān)于交叉編譯是否為提高運(yùn)行效率的最佳方法還存在討論的空間。在使用交叉編譯器時(shí),記得確保它支持你所用的版本。 Python 是一門優(yōu)秀的語言,它能讓你在短時(shí)間內(nèi)通過極少量代碼就能完成許多操作。不僅如此,它還輕松支持多任務(wù)處理,比如多進(jìn)程。 不喜歡 Pyt...
摘要:布爾值布爾值和布爾代數(shù)的表示完全一致,一個(gè)布爾值只有兩種值的數(shù)據(jù)類型可以通過內(nèi)置的函數(shù)查詢,例如還可以用來判斷和的區(qū)別在于不會(huì)認(rèn)為子類是一種父類類型。會(huì)認(rèn)為子類是一種父類類型?;竟δ苁沁M(jìn)行成員關(guān)系測(cè)試和刪除重復(fù)元素。 ...
摘要:于是打算看一下流暢的。第一章是講數(shù)據(jù)模型,主要是的魔術(shù)方法特殊方法,它們以雙下劃線開頭和結(jié)束,能讓我們自己寫的類擁有類似內(nèi)置對(duì)象那樣的屬性和方法。第三個(gè)出場(chǎng)的的是,把對(duì)象用字符串的形式表示出來。第六個(gè)是,用于實(shí)現(xiàn)自己定義的布爾值。 接觸 Python 有一段時(shí)間了,但是到現(xiàn)在也沒怎么用 Python 寫過一些有用的東西?;A(chǔ)雖然還行,但更深入的就不怎么了解了。于是打算看一下《流暢的 P...
摘要:開篇就要提到一個(gè)大的話題編程范型。例如,在面向?qū)ο缶幊讨?,程序員認(rèn)為程序是一系列相互作用的對(duì)象,而在函數(shù)式編程中一個(gè)程序會(huì)被看作是一個(gè)無狀態(tài)的函數(shù)計(jì)算的串行。 開篇就要提到一個(gè)大的話題:編程范型。什么是編程范型?引用維基百科中的解釋: 編程范型或編程范式(英語:Programming paradigm),(范即模范之意,范式即模式、方法),是一類典型的編程風(fēng)格,是指從事軟件工程...
閱讀 956·2023-01-14 11:38
閱讀 936·2023-01-14 11:04
閱讀 787·2023-01-14 10:48
閱讀 2157·2023-01-14 10:34
閱讀 1005·2023-01-14 10:24
閱讀 895·2023-01-14 10:18
閱讀 545·2023-01-14 10:09
閱讀 622·2023-01-14 10:02