小甲鱼Python第二十三讲课后习题--025,字典

 
笔记:
一、字典是Python中惟一的映射类型
二、字典包含两个要素:键(key)和值(value)他们是成对出现的,用大括号括起来,多对存在时用逗号隔开。
三、能够用dict()直接建立字典,如dict1 = dict((('F',70),('i',105),('s',115),('h',104),('C',67))),建立出来的字典dict1的形式为{('F',70),('i',105),('s',115),('h',104),('C',67)}
四、dict2 = dict(key1 = value1,key2 = value2),则最后的形式为:dict2 = {key2:value2,key1:value1}Python的dict是无序的。
五、改变字典中的某个值:dict2[key] = 'value',插入的方法相似
 
测试题:
0. 当你听到小伙伴们在谈论“映射”、“哈希”、“散列”或者“关系数组”的时候,事实上他们就是在讨论什么呢?
答:是的,事实上他们就是在讨论咱们这一讲介绍的“字典”,都是一个概念!
 
1. 尝试一下将数据('F': 70, 'C': 67, 'h': 104, 'i': 105, 's': 115)建立为一个字典并访问键 'C' 对应的值?
方法一:
aaa=dict((('F',70),("C",67),("h",104),('i',105),('s',115)))
print(aaa["C"])
方法二:
aaa={'F':70,"C":67,"h":104,'i':105,'s':115}
print(aaa['C'])

2. 用方括号(“[]”)括起来的数据咱们叫列表,那么使用大括号(“{}”)括起来的数据咱们就叫字典,对吗?编程

答:不对数组

例如:测试

>>> NotADict = {1,2,3,4,5}
>>> type(NotADict)
<class 'set'>spa

不难发现,虽然咱们用大括号(“{}”)把一些数据括起来了,但因为没有反映出这些数据有映射的关系,因此建立出
来的不是字典,而是叫’set’的东西,那’set’到底又是啥玩意儿呢?请看第027讲 | 集合:在个人世界里,你就是惟
一!.net

 

3. 你如何理解有些东西字典作获得,但“万能的”列表却难以实现(臣妾作不到T_T)?code

例如:blog

>>> brand = ['李宁','耐克','阿迪达斯','鱼C工做室']
>>> slogan = ['一切皆有可能','Just do it','Impossible is nothing','让编程改变世界']
>>> print('鱼C工做室的口号是:',slogan[brand.index('鱼C工做室')])
鱼C工做室的口号是: 让编程改变世界索引

列表brand、slogan的索引和相对的值是没有任何关系的,咱们能够看出惟一有联系的就是两个列表间,索引号相同的
元素是有关系的(品牌对应口号嘛),因此这里咱们经过brand.index('鱼C工做室')这样的语句,间接的实现经过品牌
查找对应的口号的功能。
  
这确实是一种可实现方法,呃……但用起来呢,多少有些别扭,效率还不高咧。何况Python是以简洁为主,这样子的实
现确定是不能让人满意的,因此呢,咱们须要有字典这种映射类型的出现:three

>>> dict1 = {'李宁':'一切皆有可能','耐克':'Just do it','阿迪达斯':'Impossible is nothing','鱼C工做室':'让编程改变世界'}
>>> print('鱼C工做室的口号是:',dict1['鱼C工做室'])
鱼C工做室的口号是: 让编程改变世界ip

 

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)])
>>> d = dict({'three':3,'one':1,'two':2})

 

是的,他们都在建立字典:a = dict(one=1, two=2, three=3),呃,我是看不出差异啦~

实际运行效果为:

>>> a
{'two': 2, 'three': 3, 'one': 1}
>>> b
{'two': 2, 'three': 3, 'one': 1}
>>> c
{'two': 2, 'three': 3, 'one': 1}
>>> d
{'two': 2, 'three': 3, 'one': 1}

说明Python的dict()是无序的,即dict的遍历顺序与初始化顺序是不一致的。能够参考:http://book.douban.com/annotation/23775810/
Python的Dict的用法:http://blog.csdn.net/wangran51/article/details/8440848

 

5. 如图,你能够推测出打了马赛克部分的代码吗?

data.split(',')  

 

动动手:

0. 尝试利用字典的特性编写一个通信录程序吧,功能如图:

 

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

print('|‐‐‐ 感谢使用通信录程序 ‐‐‐|')

相关文章
相关标签/搜索