溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Python3的高階函數(shù)怎么用

發(fā)布時(shí)間:2022-01-25 13:38:57 來(lái)源:億速云 閱讀:158 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容介紹了“Python3的高階函數(shù)怎么用”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

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ù)稱(chēng)為高階函數(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開(kāi)始的奇數(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以?xún)?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ù)來(lái)實(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("----------------------------------------------------------")
# 忽略大小寫(xiě)對(duì)字符串列表進(jìn)行排序
nameList = ["Willard","ChenJD","ChenBao","ChenXiaoBao","hackerLuo"]
print("nameList原始內(nèi)容為:",nameList)
print("忽略大小寫(xiě)排序:",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']
忽略大小寫(xiě)排序: ['ChenBao', 'ChenJD', 'ChenXiaoBao', 'hackerLuo', 'Willard']
對(duì)列表反向排序: ['Willard', 'hackerLuo', 'ChenXiaoBao', 'ChenJD', 'ChenBao']

“Python3的高階函數(shù)怎么用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI