creature_names = [‘Sammy’, ‘Ashley’, ‘Jo’, ‘Olly’, ‘Jackie’, ‘Charlie’]
要筛选此列表以元音开头的水族馆生物的名称,lambda
函数如下:
print(list(filter(lambda x: x[0].lower() in ‘aeiou’, creature_names)))
在这里,我们将列表中的一个项声明为x
,并以x[0]
的方式访问每个字符串的第一个字符,并且要将字母转化为小写,以确保将字母与'aeiou'
中的字符匹配。
最后,要提供可迭代对向creature_name
。与上一节一样,用list()
将返回结果转化为列表表。
输出如下:
[‘Ashley’, ‘Olly’]
当然,写一个函数,也能够实现类似的结果:
creature_names = [‘Sammy’, ‘Ashley’, ‘Jo’, ‘Olly’, ‘Jackie’, ‘Charlie’]
def names_vowels(x):
return x[0].lower() in ‘aeiou’
filtered_names = filter(names_vowels, creature_names)
print(list(filtered_names))
在names_vowels
函数中用一个表达式,完成了对creature_names
的过滤。
同样,输出如下:
[‘Ashley’, ‘Olly’]
总的来说,在filter()
函数中使用lambda函数得到的结果与使用常规函数得到的结果相同。如果所要过滤数据更复杂了,还可能要使用正则表达式,这可能会提高代码的可读性。
在filter()
中使用None
我们也可以将None
作为filter()
的第一个参数,让迭代器过滤掉Python中布尔值是False
的对象,比如长度为0的对象(如空列表或空字符串)或在数字上等于0的对象。
下面的示例中要过滤一个列表,去掉其中布尔值是False
的元素。
aquarium_tanks = [11, False, 18, 21, “”, 12, 34, 0, [], {}]
filtered_tanks = filter(None, aquarium_tanks)
这段代码在filter()
中使用了None,并将aquarium_tanks
列表作为可迭代项传入。将None
作为第一个参数,可以检查列表中的元素是否为False
。
print(list(filtered_tanks))
然后再将filtered_tanks
传给list()
函数,这样就得到了一个列表。
从输出结果中可以看出,我们得到了想要的整数,那些布尔值是False
的项都筛选掉了。
[11, 18, 21, 12, 34]
注意:如果不使用list()
并打印filtered_tanks
,将得到一个类似于<filter object at 0x7fafd5903240>
这样的filter对象。filter对象是可迭代的,因此我们可以使用for循环它,也可以使用list()
将其转换为列表。
借助None
,用filter()
快速地从列表中删除被认为False
的项。
将filter()
用于复杂场景
对于复杂的数据结构,filter()
也可以胜任,例如,有一个由字典组成的列表,我们不仅要遍历列表中的每项(字典), 还可能要遍历字典中的每个键值对,以便得到所有的数据。
举个例子,假设我们有水族馆里每种生物的一个列表以及每种生物的不同细节,用下面的列表显示此数据。
aquarium_creatures = [
{“name”: “sammy”, “species”: “shark”, “tank number”: “11”, “type”: “fish”},
{“name”: “ashley”, “species”: “crab”, “tank number”: “25”, “type”: “shellfish”},
{“name”: “jo”, “species”: “guppy”, “tank number”: “18”, “type”: “fish”},
{“name”: “jackie”, “species”: “lobster”, “tank number”: “21”, “type”: “shellfish”},
{“name”: “charlie”, “species”: “clownfish”, “tank number”: “12”, “type”: “fish”},
{“name”: “olly”, “species”: “green turtle”, “tank number”: “34”, “type”: “turtle”}
]
下面就写一个函数,用这个函数来过滤这些数据。为了让filter()
访问每个字典和字典中的每个元素,这需要构造一个嵌套函数,如下所示:
如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、全套PDF电子书
书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。
四、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!