##字典:当索引不好用时
(在python中也是有字典的,python的字典把字典称为键(key),把这个单词对应的含义称之为值(value,另外,python在很多区地方也称为hash,哈希,有的地方称为关系数组。)
##映射
(字典是python唯一的一个映射类型,映射来自数学里的术语,他原本是指两个元素集之间,元素相互对应的关系,如下,从A映射到B,也就是A中每一个字母找到B里边的一个唯一的映射,a映射到m等等,彼此建立一个一对一的关系,一对多的关系,我们称为映射。映射类型我们要区别与之前讲过的序列类型,序列类型是以数组的形式存储的,通过索引的方式来取得相应位置的值,数组中,他的第一个元素他的索引值是0,以此类推,分别对应12345678这些元素的位置,那么一般索引值和对应存储的数据是毫无关系的)
##创建和访问字典
※创建语法:{键1(key):值1(value),键2(key):值2(value),…}
※访问语法:字典名.[“键的名称”]
(创建一个空的字典)
(可以用工厂函数dict()来创建,里边传进去的是映射关系,这里用的是元组,也可以用列表,只要构成一种映射关系就可以,那么为什么那么多括号,因为dict只有一个映射类型的参数,然后这里用的是元组,外面在加一个括号伪装成一个参数)
(也可以通过关键字,key+value的形式来创建字典)
(还有一种创建的方式就是直接给字典的键赋值,如果这个键在字典中已经存在了,则改写键对应的值,如果这个键是不存在的,他不会报错,他会直接创建一个新的键并为他赋值,)
##温故知新之习题
0. 当你听到小伙伴们在谈论“映射”、“哈希”、“散列”或者“关系数组”的时候,事实上他们就是在讨论什么呢?
答:是的,事实上他们就是在讨论我们这一讲介绍的“字典”,都是一个概念!(切记,装X的本质就是把同一个东西说成各种不同的事物~)
1. 尝试一下将数据(‘F’: 70, ‘C’: 67, ‘h’: 104, ‘i’: 105, ‘s’: 115)创建为一个字典并访问键 ‘C’ 对应的值?
答:
>>> MyDict = dict((('F', 70), ('i',105), ('s',115), ('h',104), ('C',67)))
>>> MyDict_2 = {'F':70, 'i':105, 's':115, 'h':104, 'C':67}
>>> type(MyDict)
<class 'dict'>
>>> type(MyDict_2)
<class 'dict'>
>>> MyDict['C']
67
2. 用方括号(“[]”)括起来的数据我们叫列表,那么使用大括号(“{}”)括起来的数据我们就叫字典,对吗?
答:不对。
>>> NotADict = {1, 2, 3, 4, 5}
>>> type(NotADict)
<class 'set'>
不难发现,虽然我们用大括号(“{}”)把一些数据括起来了,但由于没有反映出这些数据有映射的关系,所以创建出来的不是字典,而是叫’set’的东西,那’set’到底又是啥玩意儿呢?请看第027讲 | 集合:在我的世界里,你就是唯一!
3. 你如何理解有些东西字典做得到,但“万能的”列表却难以实现(臣妾做不到T_T)?
答:举个例子:
>>> brand = ['李宁', '耐克', '阿迪达斯', '鱼C工作室']
>>> slogan = ['一切皆有可能', 'Just do it', 'Impossible is nothing', '让编程改变世界']
>>> print('鱼C工作室的口号是:', slogan[brand.index('鱼C工作室')])
鱼C工作室的口号是: 让编程改变世界
列表brand、slogan的索引和相对的值是没有任何关系的,我们可以看出唯一有联系的就是两个列表间,索引号相同的元素是有关系的(品牌对应口号嘛),所以这里我们通过brand.index(‘鱼C工作室’)这样的语句,间接的实现通过品牌查找对应的口号的功能。
这确实是一种可实现方法,呃……但用起来呢,多少有些别扭,效率还不高咧。况且Python是以简洁为主,这样子的实现肯定是不能让人满意的,所以呢,我们需要有字典这种映射类型的出现:
4. 下边这些代码,他们都在执行一样的操作吗?你看得出差别吗?
>>> a = dict(one=1, two=2, three=3)
>>> b = {'one': 1, 'two': 2, 'three': 3}
>>> c = dict(zip(['one', 'two', 'three'], [1, 2, 3]))
>>> d = dict([('two', 2), ('one', 1), ('three', 3)])
>>> e = dict({'three': 3, 'one': 1, 'two': 2})
答:是的,他们都在创建字典:a = dict(one=1, two=2, three=3),呃,我是看不出差别啦~
5. 如图,你可以推测出打了马赛克部分的代码吗?
答:
data = "1000,小甲鱼,男"
MyDict = {}
# 还记得字符串的分割方法吧,别学过就忘啦^_^
(MyDict['id'], MyDict['name'], MyDict['sex']) = data.split(',')
print("ID: " + MyDict['id'])
print("Name: " + MyDict['name'])
print("Sex " + MyDict['sex'])
##动动手
0. 请使用lambda表达式将下边函数转变为匿名函数?
答:
print('|--- 欢迎进入通讯录程序 ---|')
print('|--- 1:查询联系人资料 ---|')
print('|--- 2:插入新的联系人 ---|')
print('|--- 3:删除已有联系人 ---|')
print('|--- 4:退出通讯录程序 ---|')
contacts = dict()
while 1:
instr = int(input('\n请输入相关的指令代码:'))
if instr == 1:
name = input('请输入联系人姓名:')
if name in contacts:
print(name + ' : ' + contacts[name])
else:
print('您输入的姓名不再通讯录中!')
if instr == 2:
name = input('请输入联系人姓名:')
if name in contacts:
print('您输入的姓名在通讯录中已存在 -->> ', end='')
print(name + ' : ' + contacts[name])
if input('是否修改用户资料(YES/NO):') == 'YES':
contacts[name] = input('请输入用户联系电话:')
else:
contacts[name] = input('请输入用户联系电话:')
if instr == 3:
name = input('请输入联系人姓名:')
if name in contacts:
del(contacts[name]) # 也可以使用dict.pop()
else:
print('您输入的联系人不存在。')
if instr == 4:
break