文末有福利领取哦~
👉一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
👉二、Python必备开发工具
👉三、Python视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
👉 四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。(文末领读者福利)
👉五、Python练习题
检查学习结果。
👉六、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
👉因篇幅有限,仅展示部分资料,这份完整版的Python全套学习资料已经上传
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
在这里,我们将列表中的一个项声明为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()
访问每个字典和字典中的每个元素,这需要构造一个嵌套函数,如下所示:
def filter_set(aquarium_creatures, search_string):
def iterator_func(x):
for v in x.values():
if search_string in v:
return True
return False
return filter(iterator_func, aquarium_creatures)
定义filter_set()
函数,以aquarium_creatures
和search_string
作为参数。在filter_set()
中,将内部函数iterator_func()
作为filter()
的参数。filter_set()
函数将返回由filter()
生成的迭代器。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!