一篇文章帶你學(xué)習(xí)Python3的高階函數(shù)
1.高階函數(shù)
# 1.變量指向函數(shù) # 調(diào)用函數(shù)和函數(shù)本身 print("-10的絕對(duì)值為:",abs(-10)) print("絕對(duì)值函數(shù)本身:",abs) print("--------------------------------------------------") # 把函數(shù)調(diào)用結(jié)果和函數(shù)本身賦值給變量,即變量指向函數(shù) abs1 = abs(-100) print("-100的絕對(duì)值為:",abs1) selfAbs = abs print("abs函數(shù)本身:",selfAbs) print("--------------------------------------------------") # 2.函數(shù)名也是變量 # 函數(shù)名:指向函數(shù)的變量; # 可以將abs指向-10,即:abs = -10 # 3.傳入函數(shù):一個(gè)函數(shù)可以接收另外一個(gè)函數(shù)作為參數(shù),這種函數(shù)稱為高階函數(shù); # 實(shí)例: def add(x,y,f): return f(x) + f(y) # 調(diào)用add()函數(shù) print("add(-5,-10,abs)的值為:",add(-5,-10,abs))
# 結(jié)果輸出:
-10的絕對(duì)值為: 10
絕對(duì)值函數(shù)本身: <built-in function abs>
--------------------------------------------------
-100的絕對(duì)值為: 100
abs函數(shù)本身: <built-in function abs>
--------------------------------------------------
add(-5,-10,abs)的值為: 15
2.map/reduce
# reduce # reduce把一個(gè)函數(shù)作用在一個(gè)序列[x1,x2,...]上,這個(gè)函數(shù)必須接收兩個(gè)參數(shù); # reduce把結(jié)果繼續(xù)和序列的下一個(gè)元素做累積計(jì)算; # reduce(f,[x1,x2,x3,x4]) = f(f(f(x1,x2),x3),x4) # 實(shí)例: from functools import reduce def add(x,y): return x + y numsList = [1,3,5,7,9] print("reduce作用于numsList的結(jié)果為:",reduce(add,numsList)) print("-------------------------------------------------------------") # 計(jì)算1-10的階乘 def mul(x,y): return x * y numsList = list(range(1,11)) print("使用reduce函數(shù)計(jì)算1-10的階乘:",reduce(mul,numsList)) # 結(jié)果輸出: """ reduce作用于numsList的結(jié)果為: 25 ------------------------------------------------------------- 使用reduce函數(shù)計(jì)算1-10的階乘: 3628800 """
# reduce # reduce把一個(gè)函數(shù)作用在一個(gè)序列[x1,x2,...]上,這個(gè)函數(shù)必須接收兩個(gè)參數(shù); # reduce把結(jié)果繼續(xù)和序列的下一個(gè)元素做累積計(jì)算; # reduce(f,[x1,x2,x3,x4]) = f(f(f(x1,x2),x3),x4) # 實(shí)例: from functools import reduce def add(x,y): return x + y numsList = [1,3,5,7,9] print("reduce作用于numsList的結(jié)果為:",reduce(add,numsList)) print("-------------------------------------------------------------") # 計(jì)算1-10的階乘 def mul(x,y): return x * y numsList = list(range(1,11)) print("使用reduce函數(shù)計(jì)算1-10的階乘:",reduce(mul,numsList)) # 結(jié)果輸出: """ reduce作用于numsList的結(jié)果為: 25 ------------------------------------------------------------- 使用reduce函數(shù)計(jì)算1-10的階乘: 3628800 """
3.filter
def is_odd(n): return n % 2 == 1 # 在list中刪除偶數(shù),保留奇數(shù) numsList = [1,2,5,7,19,23,3,6,9] print("numsList內(nèi)容為:",numsList) print("filter后的結(jié)果:",list(filter(is_odd,numsList))) print("--------------------------------------------------") # 用埃氏篩法求素?cái)?shù) # 1.構(gòu)造一個(gè)從3開始的奇數(shù)序列 def _odd_iter(): n = 1 while True: n = n + 2 yield n # 2.定義一個(gè)篩選函數(shù) def _not_divisible(n): return lambda x: x % n > 0 # 3.定義一個(gè)生成器,不斷返回下一個(gè)素?cái)?shù) def primes(): yield 2 it = _odd_iter() # 初始序列 while True: n = next(it) # 返回序列的第一個(gè)數(shù) yield n it = filter(_not_divisible(n), it) # 構(gòu)造新序列 # 打印1000以內(nèi)的素?cái)?shù) for n in primes(): if n < 1000: print(n,end = " ") else: break
# 結(jié)果輸出:
numsList內(nèi)容為: [1, 2, 5, 7, 19, 23, 3, 6, 9]
filter后的結(jié)果: [1, 5, 7, 19, 23, 3, 9]
--------------------------------------------------
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103 107 109 113 127 131 137 139 149 151 157 163 167 173 179 181 191 193 197 199 211 223 227 229 233 239 241 251 257 263 269 271 277 281 283 293 307 311 313 317 331 337 347 349 353 359 367 373 379 383 389 397 401 409 419 421 431 433 439 443 449 457 461 463 467 479 487 491 499 503 509 521 523 541 547 557 563 569 571 577 587 593 599 601 607 613 617 619 631 641 643 647 653 659 661 673 677 683 691 701 709 719 727 733 739 743 751 757 761 769 773 787 797 809 811 821 823 827 829 839 853 857 859 863 877 881 883 887 907 911 919 929 937 941 947 953 967 971 977 983 991 997
4.sorted
# 排序算法 # sorted()函數(shù)可以對(duì)list進(jìn)行排序; numsList = [1,2,4,3,9,6,8,7,0] print("原始的list內(nèi)容:",numsList) print("使用sorted排序后list內(nèi)容:",sorted(numsList)) print("----------------------------------------------------------") # sorted()函數(shù)可以接收一個(gè)key函數(shù)來實(shí)現(xiàn)自定義排序 # 按絕對(duì)值大小排序 numsList2 = [-10,2,3,4,6,5,-9,-8,7] print("原始的list內(nèi)容:",numsList2) print("按照絕對(duì)值排序:",sorted(numsList2,key = abs)) print("----------------------------------------------------------") # 忽略大小寫對(duì)字符串列表進(jìn)行排序 nameList = ["Willard","ChenJD","ChenBao","ChenXiaoBao","hackerLuo"] print("nameList原始內(nèi)容為:",nameList) print("忽略大小寫排序:",sorted(nameList,key = str.lower)) print("對(duì)列表反向排序:",sorted(nameList,key = str.lower,reverse = True))
# 結(jié)果輸出:
原始的list內(nèi)容: [1, 2, 4, 3, 9, 6, 8, 7, 0]
使用sorted排序后list內(nèi)容: [0, 1, 2, 3, 4, 6, 7, 8, 9]
----------------------------------------------------------
原始的list內(nèi)容: [-10, 2, 3, 4, 6, 5, -9, -8, 7]
按照絕對(duì)值排序: [2, 3, 4, 5, 6, 7, -8, -9, -10]
----------------------------------------------------------
nameList原始內(nèi)容為: ['Willard', 'ChenJD', 'ChenBao', 'ChenXiaoBao', 'hackerLuo']
忽略大小寫排序: ['ChenBao', 'ChenJD', 'ChenXiaoBao', 'hackerLuo', 'Willard']
對(duì)列表反向排序: ['Willard', 'hackerLuo', 'ChenXiaoBao', 'ChenJD', 'ChenBao']
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Python?運(yùn)算符Inplace?與Standard?
這篇文章主要介紹了Python?運(yùn)算符Inplace?與Standard,nplace運(yùn)算符的行為類似于普通運(yùn)算符,只是它們?cè)诳勺兒筒豢勺兡繕?biāo)的情況下以不同的方式運(yùn)行2022-09-09pytorch 實(shí)現(xiàn)模型不同層設(shè)置不同的學(xué)習(xí)率方式
今天小編就為大家分享一篇pytorch 實(shí)現(xiàn)模型不同層設(shè)置不同的學(xué)習(xí)率方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-01-01Python數(shù)據(jù)分析之獲取雙色球歷史信息的方法示例
這篇文章主要介紹了Python數(shù)據(jù)分析之獲取雙色球歷史信息的方法,涉及Python網(wǎng)頁抓取、正則匹配、文件讀寫及數(shù)值運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下2018-02-02使用pyshp包進(jìn)行shapefile文件修改的例子
今天小編就為大家分享一篇使用pyshp包進(jìn)行shapefile文件修改的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12在Mac OS系統(tǒng)上安裝Python的Pillow庫的教程
這篇文章主要介紹了在MacOS下安裝Python的Pillow庫的教程,Pillow庫用來對(duì)圖片進(jìn)行各種處理操作,需要的朋友可以參考下2015-11-11