高階函數(shù)就是能夠把函數(shù)當(dāng)成參數(shù)傳遞的函數(shù)就是高階函數(shù),換句話說如果一個函數(shù)的參數(shù)是函數(shù),那么這個函數(shù)就是一個高階函數(shù)。
為耀州等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及耀州網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、網(wǎng)站建設(shè)、耀州網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!
高階函數(shù)可以是你使用def
關(guān)鍵字自定義的函數(shù),也有Python系統(tǒng)自帶的內(nèi)置高階函數(shù)。
我們下面的例子中,函數(shù) senior 的參數(shù)中有一個是函數(shù),那么senior就是一個高階函數(shù);函數(shù) tenfold 的參數(shù)不是函數(shù),所以tenfold就只是一個普通的函數(shù)。
# 定義高階函數(shù)
def senior(func, container):
"""
將容器中的數(shù)據(jù)依次放入函數(shù)中進(jìn)行運(yùn)算,
將結(jié)果返回到迭代器中,最后返回迭代器。
"""
lst = list()
for i in container:
lst.append(func(i))
return iter(lst)
# 定義普通的功能函數(shù)
def tenfold(num):
"""
十倍器
將數(shù)據(jù)乘 10,返回結(jié)果。
"""
return num * 10
# 定義一個列表
lst = [10, , 'msr']
# 使用高階函數(shù)
it = senior(tenfold, lst)
print(list(it)) # [100, , 'msrmsrmsrmsrmsrmsrmsrmsrmsrmsr']
函數(shù) | 功能作用 |
---|---|
map | 處理可迭代對象中的數(shù)據(jù),將處理的結(jié)果返回到迭代器中。 |
filter | 過濾可迭代對象中的數(shù)據(jù),將過濾好的數(shù)據(jù)返回到迭代器中。 |
reduce | 處理可迭代對象中的數(shù)據(jù),將最終的結(jié)果返回出來。 |
sorted | 排序可迭代對象中的數(shù)據(jù),將排序好的結(jié)果返回出來。 |
語法:map(function, Iterable)
function:函數(shù),可以是 自定義函數(shù) 或者是 內(nèi)置函數(shù);
iterable:可迭代對象,可迭代性數(shù)據(jù)。(容器類型數(shù)據(jù)和類容器類型數(shù)據(jù)、range對象、迭代器)
把可迭代對象中的數(shù)據(jù)一個一個拿出來,然后放在到指定的函數(shù)中做處理,將處理之后的結(jié)果依次放入迭代器中,最后返回這個迭代器。
將列表中的元素轉(zhuǎn)成整型類型,然后返回出來。
lst = ['1', '2', '3', '4']
""" 使用常規(guī)的寫法 """
new_lst = list()
for i in lst:
new_lst.append(int(i))
print(new_lst) # [1, 2, 3, 4]
""" 使用map函數(shù)實(shí)現(xiàn) """
it = map(int, lst)
new_lst = list(it)
print(new_lst) # [1, 2, 3, 4]
列表中的每一個數(shù)依次乘 2的下標(biāo)索引+1 次方。使用自定義的函數(shù),配合實(shí)現(xiàn)功能。
lst = [1, 2, 3, 4]
""" 普通的方法,利用左移 """
new_lst = list()
for i in lst:
res = i << i
new_lst.append(res)
print(new_lst) # [2, 8, 24, 64]
""" 使用map函數(shù) """
# 先定義一個左移函數(shù),自定義的函數(shù)必須是一個帶參函數(shù)并且有返回值
def func(num):
return num << num
new_lst = list(map(func, lst))
print(new_lst) # [2, 8, 24, 64]
""" 使用lambda簡化 """
new_lst = list(map(lambda num: num << num, lst))
print(new_lst) # [2, 8, 24, 64]
語法:filter(function, iterable)
參數(shù)的意義和map函數(shù)一樣
filter用于過濾數(shù)據(jù),將可迭代對象中的數(shù)據(jù)一個一個的放入函數(shù)中進(jìn)行處理,如果函數(shù)返回值為真,將數(shù)據(jù)保留;反之不保留,最好返回迭代器。
保留容器中的偶數(shù)
lst = [11, 2, 3, 34, 4, 4, 55]
""" 常規(guī)寫法 """
new_lst = list()
for i in lst:
if i % 2 == 0:
new_lst.append(i)
print(new_lst) # [2, 34, 4, 4]
""" 使用filter函數(shù) """
def func(num):
if num % 2 == 0:
return True
new_lst = list(filter(func, lst))
print(new_lst) # [2, 34, 4, 4]
""" filter + lambda """
new_lst = list(filter(lambda num: True if (num % 2 == 0) else False, lst))
print(new_lst) # [2, 34, 4, 4]
語法:reduce(function, iterable)
參數(shù)含義與map、filter一致。
計(jì)算數(shù)據(jù),將可迭代對象的中的前兩個值放在函數(shù)中做出運(yùn)算,得出結(jié)果在和第三個值放在函數(shù)中運(yùn)算得出結(jié)果,以此類推,直到所有的結(jié)果運(yùn)算完畢,返回最終的結(jié)果。
根據(jù)功能我們就應(yīng)該直到,reduce中的函數(shù)需要可以接收兩個參數(shù)才可以。
reduce函數(shù)使用需要先從標(biāo)準(zhǔn)庫functools中導(dǎo)入
將列表中的數(shù)據(jù)元素組合成為一個數(shù),
from functools import reduce
lst = [2, 0, 6, 6, 6]
""" 常規(guī)方法 """
char = str()
for i in lst:
char += str(i)
print(int(char)) #
""" 使用reduse函數(shù) """
def func(x, y):
return x * 10 + y
res = reduce(func, lst)
print(res) #
""" reduce + lambda """
res = reduce((lambda x, y: (x * 10 + y)), lst)
print(res) #
語法:sorted(Iterable, key=function, reverse=False)
iterable:可迭代對象;
key:指定函數(shù),默認(rèn)為空;
reverse:排序的方法,默認(rèn)為False,意為升序;
如果沒有指定函數(shù),就單純的將數(shù)據(jù)安札ASCII進(jìn)行排序;如果指定了函數(shù),就將數(shù)據(jù)放入函數(shù)中進(jìn)行運(yùn)算,根據(jù)數(shù)據(jù)的結(jié)果進(jìn)行排序,返回新的數(shù)據(jù),不會改變原有的數(shù)據(jù)。
注意,如果指定了函數(shù),排序之后是根據(jù)數(shù)據(jù)的結(jié)果對原數(shù)據(jù)進(jìn)行排序,而不是排序計(jì)算之后的就結(jié)果數(shù)據(jù)。
將列表中的數(shù)據(jù)進(jìn)行排序。
lst = [1, 23, 34, 5, 6, 342, 12, 12, 2345, -3]
""" 使用列表的內(nèi)置函數(shù)進(jìn)行排序,默認(rèn)升序 """
lst.sort()
print(lst) # [-3, 1, 5, 6, 12, 12, 23, 34, 342, 2345]
# 降序排序
lst.sort(reverse=True)
print(lst) # [2345, 342, 34, 23, 12, 12, 6, 5, 1, -3]
lst = [1, 23, 34, 5, 6, 342, 12, 12, 2345, -3]
""" 使用sorted進(jìn)行排序 """
new_lst = sorted(lst)
print(new_lst) # [-3, 1, 5, 6, 12, 12, 23, 34, 342, 2345]
print(lst) # [1, 23, 34, 5, 6, 342, 12, 12, 2345, -3]
還有一點(diǎn)就是 sorted 函數(shù)可以將數(shù)據(jù)放入函數(shù)中進(jìn)行處理,然后根據(jù)結(jié)果進(jìn)行排序。
lst = [1, 23, 34, 5, 6, 342, 12, 12, 2345, -3]
""" 按照絕對值進(jìn)行排序 """
new_lst = sorted(lst, key=abs)
print(new_lst) # [1, -3, 5, 6, 12, 12, 23, 34, 342, 2345]
""" 按照除以10的余數(shù)進(jìn)行排序 """
def func(num):
return num % 10
new_lst = sorted(lst, key=func)
print(new_lst) # [1, 342, 12, 12, 23, 34, 5, 2345, 6, -3]
# 可以看到,我們指定函數(shù)之后排序的結(jié)果既不是原數(shù)據(jù)的絕對值、也不是原數(shù)據(jù)除以10的余數(shù),而是根據(jù)這兩種計(jì)算結(jié)果對原數(shù)據(jù)進(jìn)行了排序。
既然有了列表的內(nèi)置函數(shù)sort,為什么我們還要使用sorted函數(shù)呢?
高階函數(shù)就是將函數(shù)作為參數(shù)的函數(shù)。
map(Function,Iterable)(將可迭代性數(shù)據(jù)中的元素一一取出放入函數(shù)中進(jìn)行運(yùn)算在將結(jié)果返回,最后返回的數(shù)據(jù)類型是迭代器)
filter(Function,Iterable)(過濾數(shù)據(jù),將可迭代性數(shù)據(jù)放入函數(shù)中進(jìn)行運(yùn)算,結(jié)果為真將數(shù)據(jù)返回,反之舍棄,最會返回的數(shù)據(jù)類型是迭代器)
reduce(Function,Iterable)(計(jì)算數(shù)據(jù),將可迭代型數(shù)據(jù)中的前兩個元素拿出放入函數(shù)中進(jìn)行運(yùn)算將結(jié)果在與后一個元素進(jìn)行運(yùn)算,最后返回最終的結(jié)果)
sorted(Iterable,[key=Function],[reverse =Bool(False(default)/True)])(將可迭代型數(shù)據(jù)進(jìn)行排序,或?qū)⒖傻蛿?shù)據(jù)放入函數(shù)中進(jìn)行運(yùn)算將結(jié)果進(jìn)行排序返回)