欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一篇文章帶你學(xué)習(xí)Python3的高階函數(shù)

 更新時(shí)間:2022年01月25日 10:43:34   作者:FUXI_Willard  
這篇文章主要為大家詳細(xì)介紹了Python3的高階函數(shù),主要介紹什么是高階函數(shù),高階函數(shù)的用法以及幾個(gè)常見的內(nèi)置的高階函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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ù)來(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("----------------------------------------------------------")
# 忽略大小寫對(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é)

本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

最新評(píng)論