中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python3中map()、reduce()、filter()怎么使用

發布時間:2022-08-04 15:50:24 來源:億速云 閱讀:109 作者:iii 欄目:開發技術

本篇內容主要講解“Python3中map()、reduce()、filter()怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Python3中map()、reduce()、filter()怎么使用”吧!

1.map()

map() 可以用于在函數中對指定序列做映射,返回值是一個迭代器,其使用語法如下:

map(function, *iterables)

上面的第一個參數 function 指一個函數,第二個參數 iterable 指一個或多個可迭代對象,在執行過程中,會對可迭代對象中的每一個元素調用 function 函數做計算,最后得到一個新的迭代器對象,而這個新的迭代器對象,會包含有每次調用 function 函數的返回值。

只傳入一個可迭代對象

"""計算列表中每個元素的三次方"""
def demo_map(x):
    return x ** 3
nums = [1, 2, 3, 4, 5]
print(list(map(demo_map, nums)))  # 輸出:[1, 8, 27, 64, 125]

# 使用匿名函數
print(list(map(lambda x: x ** 3, nums)))  # 輸出:[1, 8, 27, 64, 125]

傳入多個可迭代對象

"""計算3個列表中對應下標元素的和"""
def demo_map(x, y, z):
    return x + y + z
nums1 = [1, 2, 3, 4, 5]
nums2 = [11, 22, 33, 44, 55]
nums3 = [100, 200, 300, 400, 500]
print(list(map(demo_map, nums1, nums2, nums3)))  # 輸出:[112, 224, 336, 448, 560]

# 使用匿名函數
print(list(map(lambda x, y, z: x + y + z, nums1, nums2, nums3)))  # 輸出:[112, 224, 336, 448, 560]

2.filter()

filter() 可以用于過濾序列,過濾掉不符合條件的元素,返回值也是一個迭代器,其使用語法如下:

filter(function or None, iterable)

和 map() 函數類似,上面的第一個參數 function 指一個函數,第二個參數 iterable 指一個可迭代對象,執行后會得到一個包含每次調用 function 函數返回值的迭代器。

"""找出從 -5 到 5 中能被 4 整除的所有整數"""
def demo_filter(x):
    return x % 4 == 0


nums = range(-5, 6)
print(list(nums))  # 輸出:[-5, -4, -3, -2, -1, 0, 1, 2, 3, 4, 5]

# 傳入None,只返回true的值(0是False,所以被過濾掉了)
print(list(filter(None, nums)))  # 輸入:[-5, -4, -3, -2, -1, 1, 2, 3, 4, 5]

# 傳入正常函數,過濾出 nums 中能被 4 整除的整數
print(list(filter(demo_filter, nums)))  # 輸出:[-4, 0, 4]

# 使用匿名函數
print(list(filter(lambda x: x % 4 == 0, nums)))  # 輸出:[-4, 0, 4]

針對 map() 和 filter() 函數, 這里有 2 點需要注意:

  • map 中必須傳入一個正常函數,而在 filter 函數中則可以傳正常函數或者None,當傳入None時,只返回可迭代對象中所有符合 true 的值

  • map 中支持傳多個可迭代對象,而在 filter 函數中則只能傳一個可迭代對象

3.reduce()

reduce() 可以用于對參數序列中的元素進行累積,返回的是一個值。

在 Python3 中,reduce() 已被從全局名字空間里移除了,如果想要使用它,那么需通過引入 functools 模塊來調用 reduce() 函數,其使用語法如下:

from functools import reduce
reduce(function, sequence[, initial])

上面的第一個參數 function 指一個函數,并且該函數必須含有2個參數,第二個參數 sequence 指一個序列,第三個參數 initial 指初始值,默認是None。

例如存在函數:reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]),它就相當于 ((((1+2)+3)+4)+5)。

"""計算 1-100 所有整數之和"""
'''
學習中遇到問題沒人解答?小編創建了一個Python學習交流群:711312441
尋找有志同道合的小伙伴,互幫互助,群里還有不錯的視頻學習教程和PDF電子書!
'''
from functools import reduce
def demo_reduce(x, y):
    return x + y
nums = range(1, 101)

print(reduce(demo_reduce, nums))  # 輸出:5050
# 使用匿名函數
print(reduce(lambda x, y: x + y, nums))  # 輸出:5050

# 設置初始值為 1000
print(reduce(lambda x, y: x + y, nums, 1000))  # 輸出:6050

上面的 map()、reduce()、filter() 都是屬于Python3中的高階函數,它們最大的好處在于可以讓代碼更加簡潔,當然,如果不使用它們,我們也可以通過其他方式來實現。

到此,相信大家對“Python3中map()、reduce()、filter()怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鸡西市| 临江市| 洪雅县| 富平县| 福贡县| 扶绥县| 平顶山市| 龙江县| 奉节县| 衡山县| 苏尼特右旗| 湾仔区| 凤庆县| 贡嘎县| 吕梁市| 亚东县| 瓦房店市| 齐河县| 汨罗市| 黄龙县| 博客| 额尔古纳市| 涪陵区| 陆良县| 德昌县| 理塘县| 麻阳| 麦盖提县| 乃东县| 城口县| 乌海市| 武川县| 江津市| 东港市| 手游| 通城县| 桂阳县| 淄博市| 岚皋县| 蓬莱市| 忻城县|