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

溫馨提示×

溫馨提示×

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

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

對python過濾器和lambda函數的用法詳解

發布時間:2020-09-27 16:18:11 來源:腳本之家 閱讀:303 作者:HP的博客 欄目:開發技術

1. 過濾器

Python 具有通過列表解析 將列表映射到其它列表的強大能力。這種能力同過濾機制結合使用,使列表中的有些元素被映射的同時跳過另外一些元素。

過濾列表語法: [ mapping-expression for element in source-list if filter-expression ]

這是列表解析的擴展,前三部分都是相同的,最后一部分,以 if開頭的是過濾器表達式。過濾器表達式可以是返回值為真或者假的任何表達式 (在 Python 中是幾乎任何東西)。任何經過濾器表達式演算值為真的元素都可以包含在映射中,其它的元素都將忽略,它們不會進入映射表達式,更不會包含在輸出列表中。

列表過濾介紹

>>> li = ["a", "mpilgrim", "foo", "b", "c", "b", "d", "d"]
>>> [elem for elem in li if len(elem) > 1]
['mpilgrim', 'foo']
// 由于 Python 會遍歷整個列表,它將對每個元素執行過濾器表達式,如果過濾器表達式演算值為真,該元素就會被映射,同時映射表達式的結果將包含在返回的列表中,這里過濾掉了所有單字符的字符串,留下了一個由長字符串構成的列表。

>>> [elem for elem in li if elem != "b"]
['a', 'mpilgrim', 'foo', 'c', 'd', 'd']
// 這里過濾掉了一個特定值 b ,注意這個過濾器會過濾掉所有的 b, 因為每次取出 b, 過濾表達式都將為假。

>>> [elem for elem in li if li.count(elem) == 1]
['a', 'mpilgrim', 'foo', 'c']
// count 是一個列表方法,返回某個值在列表中出現的次數,你可以認為這個過濾器將從列表中刪除重復元素,返回一個只包含了在原始列表中有著唯一值拷貝的列表。但并非如此,因為在原始列表中出現兩次的值 (在本例中, b 和 d ) 被完全剔除了,從一個列表中排除重復值有多種方法,但過濾并不是其中的一種。

filter 內置函數

Python2.7.13官方文檔中的介紹: filter(function, iterable) Construct a list from those elements of iterable for which function returns true. iterable may be either a sequence, a container which supports iteration, or an iterator. If iterable is a string or a tuple, the result also has that type; otherwise it is always a list. If function is None, the identity function is assumed, that is, all elements of iterable that are false are removed.

Note that filter(function, iterable) is equivalent to [item for item in iterable if function(item)] if function is not None and [item for item in iterable if item] if function is None.

See itertools.ifilter() and itertools.ifilterfalse() for iterator versions of this function, including a variation that filters for elements where the function returns false.

Python內建的filter()函數用于過濾序列

// 保留長度大于1的字符串
>>> li = ["a", "mpilgrim", "foo", "b", "c", "b", "d", "d"]
>>> def func(s):
... return len(s) > 1

>>> filter(func,li)
['mpilgrim', 'foo']

// 刪除奇數
>>> def del_odd(n):
... return n % 2 == 0
>>> filter(del_odd,[0,1,2,3,4,5,6,7,8,9])
[0, 2, 4, 6, 8]

2. lambda函數

Python 支持一種有趣的語法, 它允許你快速定義單行的最小函數, 這些叫做

lambda 的函數, 是從 Lisp 借用來的, 可以用在任何需要函數的地方。

>>> def f(x):
... return x*2 
>>> f(3)
6

>>> g = lambda x : x*2
>>> g(3)
6
// 這是一個 lambda 函數,完成同上面普通函數相同的事情。注意這里的簡短的語法:在參數列表周圍沒有括號,而且忽略了 return 關鍵字 (隱含存在,因為整個函數只有一行)。而且,該函數沒有函數名稱,但是可以將它賦值給一個變量進行調用。

>>> (lambda x : x*2)(3)
6
// 使用 lambda 函數時甚至不需要將它賦值給一個變量。

總的來說, lambda 函數可以接收任意多個參數 (包括可選參數) 并且返回單個表達式的值。 lambda 函數不能包含命令, 包含的表達式不能超過一個, 不要試圖向 lambda 函數中塞入太多的東西, 如果你需要更復雜的東西, 應該定義一個普通函數, 然后想讓它多長就多長。

Note: lambda函數 是可選的, 它是一種風格問題,不一定非要使用它們,任何能夠使用它們的地方,都可以定義一個單獨的普通函數來進行替換,應將它們用在需要封裝特殊的、非重用代碼上,避免代碼充斥著大量單行函數。

以上這篇對python過濾器和lambda函數的用法詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

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

AI

陕西省| 库伦旗| 佛坪县| 桂林市| 金坛市| 临沧市| 加查县| 澎湖县| 辽阳县| 阜新市| 巴里| 增城市| 双牌县| 沂南县| 桃源县| 定陶县| 黑山县| 观塘区| 江油市| 梅河口市| 尖扎县| 仁化县| 汉沽区| 冕宁县| 兴山县| 江城| 商城县| 普定县| 伊金霍洛旗| 隆德县| 嘉义市| 天津市| 开原市| 阿尔山市| 凤山县| 宁强县| 固原市| 金昌市| 孝昌县| 博爱县| 新丰县|