从列表中筛选数据的三种方式
- 迭代
from random import randint
l = [randint(-10,10) for _ in range(10)]
print(l)
result = []
for data in l:
if data>0:
result.append(data)
print(result)
结果如下:
2. 使用filter过滤函数
from random import randint
l = [randint(-10,10) for _ in range(10)]
print(l)
# 第一个参数:函数,第二个参数:可迭代数据
result = filter(lamba x: x>0, data)
print(list(result))
结果如下:
3. 列表解析
from random import randint
l = [randint(-10,10) for _ in range(10)]
print(l)
result = [data for data in l if data>0]
print(result)
结果如下:
第一种方式很容易看出来,其效率是最低的,那么第二种和第三种哪种效率更高呢?
从结果可以看出,第二种只用了297ns,而第三种用了804ns,所以使用第二种的效率会比较高
从字典中筛选数据的方式:
- 列表解析
from random import randint
d = {k:randint(60,100) for k in range(1,11)}
print(d)
result = {k:v for k,v in d.items() if v>90}
print(result)
结果如下:
从集合中筛选数据
- 集合解析
from random import randint
s = {randint(-10,10) for _ in range(10)}
print(s)
result = {x for x in s if x%2==0}
print(result)
结果如下:
2. 使用filter函数
from random import randint
s = {randint(-10,10) for _ in range(10)}
print(s)
result = filter(lambda x: x%2==0, s)
print(set(result))
结果如下: