Python函數(shù)式編程之返回函數(shù)實(shí)例詳解
高階函數(shù)除了可以接受函數(shù)作為參數(shù)外,還可以把函數(shù)作為結(jié)果值返回。
看代碼:
# -*- coding: utf-8 -*- # @File : 返回函數(shù)的高階函數(shù).py # @author: Flyme awei # @email : Flymeawei@163.com # @Time : 2022/8/21 14:48 def sum_fun(*args): def add_fun(): s = 0 for i in args: s += i return s return add_fun f = sum_fun(1, 2, 3, 4, 5, 6, 7, 8, 9) add = f() print(add) # 45
當(dāng)我們調(diào)用 sum_fun
時(shí),返回的并不是求和結(jié)果,而是求和函數(shù) add_fun
, 將其賦值給f
,當(dāng)我們?cè)谡{(diào)f
函數(shù)時(shí)才返回求和結(jié)果s
。
用filter函數(shù)來(lái)計(jì)算素?cái)?shù)
用
filter
來(lái)計(jì)算素?cái)?shù)其中一個(gè)方法是埃氏篩法。
給出要篩數(shù)值的范圍n
,找出以?xún)?nèi)的素?cái)?shù)。先用2
去篩,即把2
留下,把2
的倍數(shù)剔除掉;再用下一個(gè)質(zhì)數(shù),也就是3
篩,把3
留下,把3
的倍數(shù)剔除掉;接下去用下一個(gè)質(zhì)數(shù)5
篩,把5
留下,把5
的倍數(shù)剔除掉;不斷重復(fù)下去…
用Python高階函數(shù)來(lái)實(shí)現(xiàn)這個(gè)算法:
1、我們先寫(xiě)一個(gè)生成器構(gòu)造一個(gè)從3開(kāi)始的無(wú)限奇數(shù)序列,首先排除偶數(shù)。
def odd_num(): # 奇數(shù)生成器函數(shù) n = 1 while True: n += 2 yield n
2、寫(xiě)一個(gè)篩選的函數(shù),這里使用了匿名函數(shù),返回判斷是否為可整除數(shù)
def un_divisible(n): # 判斷是否為可整除數(shù) return lambda x: x % n > 0
3、使用filter
來(lái)過(guò)濾,不斷返回素?cái)?shù)的生成迭代
def primes(): # 素?cái)?shù)生成器函數(shù) yield 2 it = odd_num() while True: n = next(it) yield n it = filter(un_divisible(n), it) # 過(guò)濾出不可以整除的數(shù)
4、判斷素?cái)?shù)方法就產(chǎn)生了,這里需要手動(dòng)結(jié)束一下
for i in primes(): # 打印小于100的素?cái)?shù) if i < 100: print(i) else: break
高階函數(shù)實(shí)現(xiàn)打印小于100的素?cái)?shù):
# -*- coding: utf-8 -*- # @File : 返回函數(shù)計(jì)算質(zhì)數(shù).py # @author: Flyme awei # @email : Flymeawei@163.com # @Time : 2022/8/21 15:17 # 得到所有的質(zhì)數(shù),打印小于100的所有的質(zhì)數(shù) # 最小的質(zhì)數(shù)是2, 質(zhì)數(shù):只能被1和它本身整除的數(shù) # 思路:先得到所有大于1的奇數(shù), --> 生成器,在把生成器中的所有元素過(guò)濾去掉: 那些可以被小于元素本身的質(zhì)數(shù)整除的數(shù) # 1.得到所有的大于1奇數(shù)的生 def odd_num(): n = 1 while True: n += 2 yield n def un_divisible(n): # 判斷是否能夠整除的函數(shù),n代表從生成器中拿到的一個(gè)大于1的質(zhì)數(shù) return lambda x: x % n > 0 # x是某一個(gè)奇數(shù),n:小于當(dāng)前x的一個(gè)質(zhì)數(shù) # 2.創(chuàng)建一個(gè)質(zhì)數(shù)的生成器,最小的質(zhì)數(shù)是2 def primes(): yield 2 n = odd_num() # g為大于1的奇數(shù)生成器 while True: x = next(n) g = filter(un_divisible(n), n) yield x for i in primes(): if i < 100: print(i, end=' ') else: break
第一段代碼生成了以3開(kāi)始的奇數(shù)序列
第二段代碼自定義過(guò)濾函數(shù),包含匿名函數(shù),判斷值的取余是否能被整除
第三段代碼用來(lái)返回素?cái)?shù),這里先返回一個(gè)2為素?cái)?shù),因?yàn)榕紨?shù)都被排除了所
這就是100以?xún)?nèi)的所有素?cái)?shù):
總結(jié)
到此這篇關(guān)于Python函數(shù)式編程之返回函數(shù)的文章就介紹到這了,更多相關(guān)Python返回函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python取均勻不重復(fù)的隨機(jī)數(shù)方式
今天小編就為大家分享一篇python取均勻不重復(fù)的隨機(jī)數(shù)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11Keras之自定義損失(loss)函數(shù)用法說(shuō)明
這篇文章主要介紹了Keras之自定義損失(loss)函數(shù)用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-06-06python格式化字符串的實(shí)戰(zhàn)教程(使用占位符、format方法)
我們經(jīng)常會(huì)用到%-formatting和str.format()來(lái)格式化,下面這篇文章主要給大家介紹了關(guān)于python格式化字符串的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08python如何使用python-docx調(diào)整Word文檔樣式
本文介紹了如何修改文字字體樣式、對(duì)齊樣式、行間距以及段前段后間距,并通過(guò)效果展示給出參考,適用于需要進(jìn)行文檔編輯的讀者2024-09-09python 3調(diào)用百度OCR API實(shí)現(xiàn)剪貼板文字識(shí)別
這篇文章主要為大家詳細(xì)介紹了python 3調(diào)用百度OCR API實(shí)現(xiàn)剪貼板文字識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-09-09Python實(shí)現(xiàn)UDP程序通信過(guò)程圖解
這篇文章主要介紹了Python實(shí)現(xiàn)UDP程序通信過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05