通用做法是:迭代
data = [1, 2,4,5,6]
res = []
for x in data:
if x>=6:
res.append(x
Python 内建的 filter()函数用于过滤序列。 和 map()类似, filter()也接收一个函数和一个序列。和 map()不同的时, filter()把传入的函数依次作用于每个元素,然后根据返回值是 True 还 是 False 决定保留还是丢弃该元素。
In [4]:
def is_odd(n):
return n % 2 == 1
注意到 filter()函数返回的是一个 Iterator,也就是一个惰性序列,所 以要强迫 filter()完成计算结果,
需要用 list()函数获得所有结果并返 回 list。
In [12]:
a = (filter(is_odd, [1, 2, 4, 5, 6, 9, 10, 15]))
list(a)
Out[12]:
In [ ]:
In [6]:
from random import randint
# Python中对于无需关注其实际含义的变量可以用_代替,
# 这就和for i in range(5)一样,因为这里我们对i并不关心,所以用_代替仅获取值而已。
data = [randint(-10, 10) for _ in range(10)]
data
Out[6]:
In [8]:
filter?
匿名函数有个限制,就是只能有一个表达式,不用写 return,返回值就是该表达式的结果。
用匿名函数有个好处,因为函数没有名字,不必担心函数名冲突。此外, 匿名函数也是一个函数对象,也可以把匿名函数赋值给一个变量,再利 用变量来调用该函数: 同样,也可以把匿名函数作为返回值返回,比如:
def build(x, y):
return lambda: x * x + y * y
Python 对匿名函数的支持有限,只有一些简单的情况下可以使用匿名函 数。
In [16]:
list(filter(lambda x: x>=0, data))
Out[16]:
In [15]:
data
Out[15]:
In [17]:
[x for x in data if(x >=0)]
Out[17]:
In [21]:
%timeit list(filter(lambda x: x>=0, data))
In [22]:
timeit [x for x in data if(x >=0)]
In [23]:
d = {x: randint(60, 100) for x in range(1, 21)}
In [24]:
d
Out[24]:
默认情况下, dict 迭代的是 key。如果要迭代 value,可以用 for value in d.values(),
如果要同时迭代 key 和 value,可以用 for k, v in d.items()。
In [32]:
{k:v for k ,v in d.items() if v > 80}
Out[32]:
In [33]:
data
Out[33]:
In [34]:
s = set(data)
In [35]:
s
Out[35]:
In [36]:
{x for x in s if x%3 ==0}
Out[36]: