-
字典中每一个 key 一定是唯一的,绝对不可能存在两个相同的 kay。
-
字典中的数据量是没有限制的。
-
字典中的 value 可以是任何 Python 中的内置数据类型的对象和自定义对象。
尝试做一个小练习
电影院将近期播放的电影按战争电影、爱情电影和科幻电影进行分类,并存储到如下字典中
books_dict = {
“warfare”: [“父辈的旗帜”, “风语者”, “红男爵”, “拯救大兵瑞恩”],
“love”: [“罗马假日”, “怦然心动”, “时空恋旅人”, “天使爱美丽”, “天使之城”, “倒霉爱神”],
“science_fiction”: [“流浪地球”, “宇宙追缉令”, “时间管理局”, “命运管理局”]
}
还有几部魔幻电影没有存储,《指环王》《哈利波特》《黑夜传说》和《加勒比海盗》,将其放入字典中,并且统计一下,一共有多少部电影需要排期播放。
代码示例如下:
films_dict = {
‘warfare’: [‘父辈的旗帜’, ‘风语者’, ‘红男爵’, ‘拯救大兵瑞恩’],
‘love’: [‘罗马假日’, ‘怦然心动’, ‘时空恋旅人’, ‘天使爱美丽’, ‘天使之城’, ‘倒霉爱神’],
‘science_fiction’: [‘流浪地球’, ‘宇宙追缉令’, ‘时间管理局’, ‘命运管理局’]
}
film_fiction = {‘fantasy’:[‘指环王’, ‘哈利波特’, ‘黑夜传说’, ‘加勒比海盗’]}
films_dict.update(film_fiction)
print(films_dict[fantasy])
执行结果如下:
>>> [‘指环王’, ‘哈利波特’, ‘黑夜传说’, ‘加勒比海盗’]
warfare= films_dict[‘warfare’]
love = films_dict[‘love’]
science_fiction = films_dict[‘science_fiction’]
fantasy = films_dict[‘fantasy’]
count_films = len(warfare) + len(love) + len(science_fiction) + len(fantasy)
print(‘一共有{}部电影需要排期’.format(count_films))
执行结果如下:
>>> 一共有18部电影需要排期
字典中的 keys 函数
keys 函数的功能:获取当前字典的所有键(key)
keys 函数的用法:dict.keys()
,无需传参,返回一个 key 集合的伪列表
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
print(user.keys())
执行结果如下:
>>> dict_keys([‘name’, ‘age’, ‘birthday’])
>>> dict_keys 不具备列表的所有功能,无法通过索引获取成员(元素),也无法进行增加、修改等操作
那么如何将 dict_keys 这个伪列表进行修改,使其具备 列表 的相关功能呢?我们看下面的例子
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
user_list = list(user.keys())
user_list.append(‘sex’)
print(user_list)
执行结果如下:
>>> [‘name’, ‘age’, ‘birthday’, ‘sex’]
如此,dict_keys 就具备了列表的所有功能
字典中的 values 函数
values 函数的功能:获取当前字典的所有键值对的值(value)
values 函数的用法:dict.values()
,无需传参,返回一个 value 集合的伪列表
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
print(user.values())
执行结果如下:
>>> dict_values([‘Neo’, 18, ‘2000-01-01’])
>>> dict_values 不具备列表的所有功能,无法通过索引获取成员(元素),也无法进行增加、修改等操作
那么如何将 dict_keys 这个伪列表进行修改,使其具备 列表 的相关功能呢?我们看下面的例子
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
user_list = list(user.values())
user_list.append(‘man’)
print(user_list)
执行结果如下:
>>> [‘Neo’, 18, ‘2000-01-01’, ‘man’]
如此,dict_values 就具备了列表的所有功能
字典中 key 的获取
[ ] 的获取方法
在索引中, [ ] 可以获取索引对应的值;如果加上 “=” 和 值,那就是修改索引的值。在字典中通过 “[ ]” 来获取值的方式和索引是一致的,只要不书写 “=” 和 值 ,就是获取当前 key 的value。
-
字典 + [ ] :中括号内传入 key ,不进行赋值操作,即为获取。
-
返回 key 对应的 value 值
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
name = user[‘name’]
print('‘user’字典 name 的值为:’,name)
执行结果如下:
>>> 'user’字典 name 的值为: Neo
字典内置函数 get 获取方法
get 函数的功能:获取当前指定的 key 的 value
get 函数的用法:dict.get(key, default=Node)
, key 为需要获取 value 的 key,default 为当 key 不存在的时候返回的默认值,默认是 Node,我们也可以自定义。
注意:
当我们尝试使用 自定义 default 的时候 (dict.get(key, default='键值不存在')
),产生了 TypeError: dict.get() takes no keyword arguments
的报错信息。
解决方法:
get("key", default=Node)
方法不要添加 default=
,删除这个写法并不影响使用逻辑,但是加上会导致报错,我们可以尝试直接传入 值 或者 对应的变量提示信息。
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
default_info = ‘当前传入的 key 不存在’
name = user.get(‘name’, default_info)
print(name)
执行结果如下:
>>> Neo
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
default_info = ‘当前传入的 key 不存在’
name = user.get(‘sex’, default_info)
print(name)
执行结果如下:
>>> 当前传入的 key 不存在
[ ] 与 get 的区别
-
[ ] 如果获取的 key 不存在,则直接报错
-
get 函数 如果获取的 key 不存在,则返回默认值
-
开发过程中,建议优先使用 get() 函数
clear 函数
clear 函数的功能:清空当前字典中的素有数据
clear 函数的用法: dict.clear()
, 无参数, 无返回值
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
user.clear()
print(user)
执行结果如下:
>>> {}
pop 函数
pop 函数的功能:删除字典中指定的 key ,并将其结果返回,如果 key 不存在则报错。
pop 函数的用法: dict.pop(key)
,删除括号内指定的 key ,并返回这个 key 对应的 value。
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
pop_value = user.pop(‘birthday’)
print('‘pop_value’删除的’birthday’的’value’为:’,pop_value, '‘user’字典为:’, user)
执行结果如下:
>>> 'pop_value’的’value’为: 2000-01-01 'user’字典为: {‘name’: ‘Neo’, ‘age’: 18}
del 函数
del函数的功能:删除字典中指定的 key 或者删除整个字典
del函数的用法:del dict['key']
, del dict
示例如下:
user = {‘name’:‘Neo’, ‘age’:18, ‘birthday’:‘2000-01-01’}
del user[‘birthday’]
print('‘user’字典为:’, user)
执行结果如下:
>>> 'user’字典为: {‘name’: ‘Neo’, ‘age’: 18}
del user
print(user)
执行结果如下:
>>> NameError: name ‘user’ is not defined. Did you mean: ‘super’?
这里的 user 变量已经被完全删除了
copy 函数
copy函数的功能:将当前字典复制一个新的字典,这个新的字典与原来的字典不共享同一个内存地址。
copy函数的用法:dict.copy()
, 该函数无参数 , 返回一个内容一模一样但内存地址不同的字典。
示例如下:
old_user = {‘name’: ‘Neo’, ‘age’: 18, ‘birthday’: ‘2000-01-01’}
new_user = old_user.copy()
print(old_user)
print(new_user)
执行结果如下:
>>> {‘name’: ‘Neo’, ‘age’: 18, ‘birthday’: ‘2000-01-01’}
>>> {‘name’: ‘Neo’, ‘age’: 18, ‘birthday’: ‘2000-01-01’}
print(‘“old_user” 的内存地址为:’, id(old_user), ‘“new_user” 的内存地址为:’, id(new_user))
执行结果如下:
>>> “old_user” 的内存地址为: 140464840867968 “new_user” 的内存地址为: 140464841281088
在 列表 与 元组 的学习中,我们也接触了成员运算符 in
与 not in
的使用,与 列表、元组 不一样的是,成员运算符在字典中只能判断 key 是否存在。
示例如下:
test_dict = {‘name’: ‘Neo’}
print(‘name’ in test_dict)
print(‘name’ not in test_dict)
执行结果如下:
>>> True
如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、全套PDF电子书
书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。
四、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!