zoukankan      html  css  js  c++  java
  • 零基础入门学习Python(25)--字典:当索引不好用时

    知识点

    字典属于映射类型。

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

    • 创建及访问字典
    #创建一个字典
    >>> 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('
    请输入相关的指定代码:'))
    
        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('|--- 感谢使用通讯录程序 ---|')
    
  • 相关阅读:
    使用comet架构实现了一个基于网页的视频监控prototype!!!!哇哈哈庆祝一下
    Pixysoft.Framework.Noebe.Datamining 数据挖掘开发实录
    论创业成功!让大家的青春充满着无限美好的回忆
    新年第一篇 数据库备份恢复系统上线的挫折
    .Net FrameWork 4.0中使用EF向数据库插入数据报datatime2类型错误的解决办法
    RoRoWoBlog 开源博客系统介绍
    第一次偶然出现的“System.Data.Entity.dll”类型的异常
    序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用
    我也来说说Entity Frame Work 4中的数据库优先和代码优先两种方式(2)
    Asp.net MVC 2 + Castle + NHibernate 项目实战(1)
  • 原文地址:https://www.cnblogs.com/wanbin/p/9514685.html
Copyright © 2011-2022 走看看