零基础入门学习Python(25)--字典:当索引不好用时

mac2022-06-30  67

知识点

字典属于映射类型。

列表,元祖,字符串等属于序列类型

创建及访问字典 #创建一个字典 >>> dict1 = {'李宁':'一切皆有可能','耐克':'Just do it','阿迪达斯':'Impossible is nothing','鱼C工作室':'让编程改变世界'} 键(key):李宁 值(value):一切皆有可能 #访问字典 >>> print('鱼C工作室的口号是:',dict1['鱼C工作室']) 鱼C工作室的口号是: 让编程改变世界 >>> dict2 ={1:'one',2:'two',3:'three'} >>> dict2[2] 'two' 创建一个空字典 创建一个空字典: >>> dict1 = {} >>> dict1 {} 或者 >>> dict3 = dict() >>> dict3 {} 创建字典的一些其他方法

dict(mapping)从映射对象(key,value)中初始化的新字典,例如:

>>> dict4 = dict((('F',70),('i',105),('s',115),('h',104),('C',67))) >>> dict4 {'F': 70, 'i': 105, 's': 115, 'h': 104, 'C': 67} # mapping可以是列表,也可以是元祖 >>> dict1 = dict((['F',70],['i',105],['s',115],['h',104],['C',67])) >>> dict1 {'F': 70, 'i': 105, 's': 115, 'h': 104, 'C': 67}

dict(**kwargs)用关键字参数列表中的name = value对初始化的新字典。 例如:

>>> dict5 = dict(小甲鱼='让编程改变世界',苍井空='让xx征服所有宅男') >>> dict5 {'小甲鱼': '让编程改变世界', '苍井空': '让xx征服所有宅男'}

直接给字典的key赋值:

>>> dict5 {'小甲鱼': '让编程改变世界', '苍井空': '让xx征服所有宅男'} >>> dict5['苍井空'] = '所有xx从业者都要通过学习编程来提高职业技能' >>> dict5 {'小甲鱼': '让编程改变世界', '苍井空': '所有xx从业者都要通过学习编程来提高职业技能'} >>> >>> dict5['爱迪生'] = '天才' >>> dict5 {'小甲鱼': '让编程改变世界', '苍井空': '所有xx从业者都要通过学习编程来提高职业技能', '爱迪生': '天才'}

课后习题

测试题

尝试一下将数据('F':30,'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 用方括号[]括起来的数据我们叫列表,那么使用大括号{}括起来的数据我们就叫字典,对吗? >>> a = {1, 2, 3, 4, 5} >>> type(a) <class 'set'>

不难发现,虽然我们用大括号{}把一些数据括起来了,但由于没有反映出这些数据有映射的关系,所以创建出来的不是字典,而是叫set的东西

你如何理解有些字典做得到,但“万能的”列表却难以实现? #举个例子 >>> 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工作室的口号是: 让编程改变世界 下边这些代码,他们都在执行一样的操作吗?你看得出差别吗? >>> a = dict(one=1, two=2, three=3) >>> a {'one': 1, 'two': 2, 'three': 3} >>> b = {'one': 1, 'two': 2, 'three': 3} >>> b {'one': 1, 'two': 2, 'three': 3} >>> c = dict(zip(['one', 'two', 'three'], [1, 2, 3])) >>> c {'one': 1, 'two': 2, 'three': 3} >>> d = dict([('two', 2), ('one', 1), ('three', 3)]) >>> d {'two': 2, 'one': 1, 'three': 3} >>> e = dict({'three': 3, 'one': 1, 'two': 2}) >>> e {'three': 3, 'one': 1, 'two': 2} 如图,你可以推测出打了马赛克部分的代码吗? #利用字符串的分割方法。 data = '1000,小甲鱼,男' MyDict = {} (MyDict['id'],MyDict['name'],MyDict['sex']) = data.split(',') print("ID: " + MyDict['id']) print("Name: " + MyDict['name']) print("Sex: " + MyDict['sex']) ID: 1000 Name: 小甲鱼 Sex: 男

动动手

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

print('|--- 欢迎进入通讯录程序 ---|') print('|--- 1:查询联系人资料 ---|') print('|--- 2:插入新的联系人 ---|') print('|--- 3:删除已有联系人 ---|') print('|--- 4:退出通讯录程序 ---|') txl = dict() while 1: instr = int(input('\n请输入相关的指定代码:')) if instr == 1: name = input('请输入联系人姓名:') if name in txl: print(name + ':' + txl[name]) else: print('您输入的姓名不在通讯录中!') if instr == 2: name = input('请输入联系人姓名:') if name in txl: print('您输入的姓名已存在 -->>',end='') print(name + ':' + txl[name]) if input('是否修改用户资料(YES/NO):').upper() == 'YES': txl[name] = input('请输入用户联系电话:') else: txl[name] = input('请输入用户联系电话:') if instr == 3: name = input('请输入联系人姓名:') if name in txl: del(txl[name]) else: print('您输入的联系人不存在。') if instr == 4: break print('|--- 感谢使用通讯录程序 ---|')

转载于:https://www.cnblogs.com/wanbin/p/9514685.html

相关资源:JAVA上百实例源码以及开源项目
最新回复(0)