0.当你听到小伙伴们在谈论“映射”、“哈希”、“散列”或者“关系数组”的时候,事实上他们就是在讨论什么呢?
me:字典
参考答案:是的,事实上他们就是在讨论我们这一讲介绍的“字典”,都是一个概念!(切记,装X的本质就是把同一个东西说成各种不同的事物~)
1.尝试一下将数据('F': 70, 'C': 67, 'h': 104, 'i': 105, 's': 115)创建为一个字典并访问键 'C' 对应的值?
me:
dict1={'F': 70, 'C': 67, 'h': 104, 'i': 105, 's': 115} print(dict1["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. 用方括号(“[]”)括起来的数据我们叫列表,那么使用大括号(“{}”)括起来的数据我们就叫字典,对吗?
me:不对,只是列表的表达形式是用[]将数据括起来,字典的表达形式是使用{}将数据括起来,但是使用{}括起来的数据并不能表示为字典
参考答案:
>>> NotADict = {1, 2, 3, 4, 5} >>> type(NotADict) <class 'set'>
不难发现,虽然我们用大括号(“{}”)把一些数据括起来了,但由于没有反映出这些数据有映射的关系,所以创建出来的不是字典,而是叫’set’的东西,那’set’到底又是啥玩意儿呢?请看第027讲 | 集合:在我的世界里,你就是唯一!
3.你如何理解有些东西字典做得到,但“万能的”列表却难以实现(臣妾做不到T_T)?
me:
参考答案:
>>> brand = ['李宁', '耐克', '阿迪达斯', '鱼C工作室'] >>> slogan = ['一切皆有可能', 'Just do it', 'Impossible is nothing', '让编程改变世界'] >>> print('鱼C工作室的口号是:', slogan[brand.index('鱼C工作室')]) 鱼C工作室的口号是: 让编程改变世界
列表brand、slogan的索引和相对的值是没有任何关系的,我们可以看出唯一有联系的就是两个列表间,索引号相同的元素是有关系的(品牌对应口号嘛),所以这里我们通过brand.index('鱼C工作室')这样的语句,间接的实现通过品牌查找对应的口号的功能。
这确实是一种可实现方法,呃……但用起来呢,多少有些别扭,效率还不高咧。况且Python是以简洁为主,这样子的实现肯定是不能让人满意的,所以呢,我们需要有字典这种映射类型的出现:
>>> dict1 = {'李宁':'一切皆有可能', '耐克':'Just do it', '阿迪达斯':'Impossible is nothing', '鱼C工作室':'让编程改变世界'} >>> print('鱼C工作室的口号是:', dict1['鱼C工作室']) 鱼C工作室的口号是: 让编程改变世界
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})
me:
参考答案:是的,他们都在创建字典:a = dict(one=1, two=2, three=3),呃,我是看不出差别啦~
5.如图,你可以推测出打了马赛克部分的代码吗?
me:
date="100,小甲鱼,男" MyDict={} (MyDict["id"],MyDict["name"],MyDict["sex"])=date.split(",",3) print("ID: " + MyDict["id"]) print("name: " + MyDict["name"]) print("sex: " +MyDict["sex"])
参考答案:
动手:
data = "1000,小甲鱼,男" MyDict = {} # 还记得字符串的分割方法吧,别学过就忘啦^_^ (MyDict['id'], MyDict['name'], MyDict['sex']) = data.split(',') print("ID: " + MyDict['id']) print("Name: " + MyDict['name']) print("Sex " + MyDict['sex'])
0.尝试利用字典的特性编写一个通讯录程序吧,功能如图:
me:
print(""" |---欢迎进入通讯录程序---| |---1:查询联系人资料 ---| |---2:插入新的联系人 ---| |---3:删除已有联系人 ---| |---4:退出通讯录程序 ---| """) dictTX=dict() while 1: InputY = int(input("请输入相关的指令代码:")) if InputY == 1: name = input("请输入联系人姓名:") print(name + ":" + dictTX[name]) elif InputY == 2 : name = input("请输入联系人姓名:") if name in dictTX: print("您输入的姓名已经在通讯录中 -->> ",name," : ",dictTX[name]) temp = input("是否需要修改用户资料(YES/NO):") if temp == "YES": namder = input("请输入用户联系电话:") dictTX[name] = namder else: namder = input("请输入用户联系电话:") dictTX[name] = namder elif InputY == 3: name=input("请输入联系人姓名:") if name in dictTX: del dictTX[name] else: print(name,"不在通讯录中;") elif InputY == 4: print("|--- 感谢使用通讯录程序 ---|") break
参考答案:
print('|--- 欢迎进入通讯录程序 ---|') print('|--- 1:查询联系人资料 ---|') print('|--- 2:插入新的联系人 ---|') print('|--- 3:删除已有联系人 ---|') print('|--- 4:退出通讯录程序 ---|') contacts = dict() while 1: instr = int(input(' 请输入相关的指令代码:')) 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('|--- 感谢使用通讯录程序 ---|')