最后
🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
删除
使用del,不建议手动删除整个字典
d1 = {2:3,3:4}
del d1[2]
d1
{3: 4}
del d1
d1
Traceback (most recent call last):
File “”, line 1, in
NameError: name ‘d1’ is not defined
操作符
访问、添加、更新([])
d[1]
3
d[2]=10
d
{1: 3, 4: 5, 6: ‘lady’, ‘killer’: 9, 7: True, 2: 10}
d[6]=6
d
{1: 3, 4: 5, 6: 6, ‘killer’: 9, 7: True, 2: 10}
标准操作符(>,<,<=,>=,==,!=)
,<,<=,>=不支持dict与dict进行比较,==,!=可以判断是否每个key对应的每个value都相等。对于比较可以查看后面的cmp。
d
{1: 3, 4: 5, 6: 6, ‘killer’: 9, 7: True, 2: 10}
d1 = {1:3,4:5,6:6,‘killer’:10,7:True,2:10}
d<d1
Traceback (most recent call last):
File “”, line 1, in
TypeError: ‘<’ not supported between instances of ‘dict’ and ‘dict’dd1
False
d>=d1
Traceback (most recent call last):
File “”, line 1, in
TypeError: ‘>=’ not supported between instances of ‘dict’ and ‘dict’
d!=d1
True
d1[‘killer’]=9
dd1
True
判断键是否存在(成员关系操作in,not in)
字典没有has_key函数了
2 in d
True
3 not in d
True
方法
键值对视图
items()
d.items()
dict_items([(1, 3), (4, 5), (6, 6), (‘killer’, 9), (7, True), (2, 10)])
键视图
keys()
d.keys()
dict_keys([1, 4, 6, ‘killer’, 7, 2])list(d)
[1, 4, 6, ‘killer’, 7, 2]
值视图
values()
d.values()
dict_values([3, 5, 6, 9, True, 10])
前面三个返回的都是视图对象。该对象提供字典条目的一个动态视图,这意味着当字典改变时,视图也会相应改变。 大多数情况下我们希望得到的是列表,可以使用list()进行转换,对于keys()来说,list(d)与list(d.keys())是一样的。
返回键对应的值
get(key[,default])
如果 key 存在于字典中则返回 key 的值,否则返回 default。 如果 default 未给出则默认为 None
。
d.get(‘killer’)
9
d.get(‘lady’)
设置默认值
setdefault(key,default)
如果字典存在键 key ,返回它的值。如果不存在,插入值为 default 的键 key ,并返回 default 。 default 默认为 None
。
就是不更新,只添加,或者说安全的添加防止覆盖,其实自己使用in来实现的话也很简单,python还是贴心的帮你写了。
>>> d.setdefault(‘killer’,‘frank’)
9d.setdefault(‘lady’,‘yu’)
‘yu’
d.get(‘lady’)
‘yu’
浅拷贝
copy()
返回原字典的浅拷贝。
d1=d.copy()
d1
{1: 3, 4: 5, 6: 6, ‘killer’: 9, 7: True, 2: 10, ‘lady’: ‘yu’}
删除键值对
pop(key)
如果 key 存在于字典中则将其移除并返回对应value,否则返回 default。 如果 default 未给出且 key 不存在于字典中,则会引发KeyError
。
d1.pop(‘killer’)
9
d1.pop(‘killer’)
Traceback (most recent call last):
File “”, line 1, in
KeyError: ‘killer’
popitem()
从字典中移除并返回一个 (键, 值)
对。 键值对会按 LIFO(Last in,First out 后进先出)的顺序被返回。如果字典为空,则会引发KeyError
。
d1.popitem()
(‘lady’, ‘yu’)
d1.popitem()
(2, 10)
d1.popitem()
(7, True)
d1.popitem()
(6, 6)
d1.popitem()
(4, 5)
d1.popitem()
(1, 3)
d1.popitem()
Traceback (most recent call last):
File “”, line 1, in
KeyError: ‘popitem(): dictionary is empty’
无论数据库,各种编程语言或其他应用也好,无非就是CRUD,在CUD之前通过R来判断是比较好的习惯。
创建并返回字典
fromkeys(iterable,[None/value])
使用来自 iterable 的键创建一个新字典,并将键值设为 value。第二个参数不填,默认为None。
d1 = d.fromkeys(d.keys(),9)
d1
{1: 9, 4: 9, 6: 9, ‘killer’: 9, 7: 9, 2: 9, ‘lady’: 9}d2 = d.fromkeys([1,2,3,4,5])
d2
{1: None, 2: None, 3: None, 4: None, 5: None}
合并
update(other)
使用来自 other 的键/值对更新字典,覆盖原有的键。python3不像c++有multimap(同一个键对应多个value),所以调用update方法的字典就会被覆盖,如果键值相同保留的话可以将value作为列表,若有相同的key,value扩充即可。
d2.update(d1)
d2
{1: 9, 2: 9, 3: None, 4: 9, 5: None, 6: 9, ‘killer’: 9, 7: 9, ‘lady’: 9}
清空
clear()
移除字典中的所有元素。
d2.clear()
d2
{}
相关内置函数
长度
len()
len(d)
7
字符串
str()
用于打印比较方便
str(d)
“{1: 3, 4: 5, 6: 6, ‘killer’: 9, 7: True, 2: 10, ‘lady’: ‘yu’}”
排序
sorted(iterable,key,reverse)
对键排序
del d[‘lady’]
del d[‘killer’]
d
{1: 3, 4: 5, 6: 6, 7: True, 2: 10}sorted(d)
[1, 2, 4, 6, 7]
sorted(d,reverse=True)
[7, 6, 4, 2, 1]
对值排序
sorted(d.values())
[True, 3, 5, 6, 10]
sorted(d.values(),reverse=True)
[10, 6, 5, 3, True]
对键值对排序
sorted(d.items(),key=lambda d:d[0])
[(1, 3), (2, 10), (4, 5), (6, 6), (7, True)]
sorted(d.items(),key=lambda d:d[0],reverse=True)
[(7, True), (6, 6), (4, 5), (2, 10), (1, 3)]
sorted(d.items(),key=lambda d:d[1])
[(7, True), (1, 3), (4, 5), (6, 6), (2, 10)]
sorted(d.items(),key=lambda d:d[1],reverse=True)
[(2, 10), (6, 6), (4, 5), (1, 3), (7, True)]
字典推导式
最后
Python崛起并且风靡,因为优点多、应用领域广、被大牛们认可。学习 Python 门槛很低,但它的晋级路线很多,通过它你能进入机器学习、数据挖掘、大数据,CS等更加高级的领域。Python可以做网络应用,可以做科学计算,数据分析,可以做网络爬虫,可以做机器学习、自然语言处理、可以写游戏、可以做桌面应用…Python可以做的很多,你需要学好基础,再选择明确的方向。这里给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
👉Python所有方向的学习路线👈
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
👉Python必备开发工具👈
工欲善其事必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
👉Python全套学习视频👈
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
👉实战案例👈
学python就与学数学一样,是不能只看书不做题的,直接看步骤和答案会让人误以为自己全都掌握了,但是碰到生题的时候还是会一筹莫展。
因此在学习python的过程中一定要记得多动手写代码,教程只需要看一两遍即可。
👉大厂面试真题👈
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!