• Python基础知识之2——字典


      字典是什么?

    字典是另外一个可变的数据结构,且可存储任意类型对象,比如字符串、数字、列表等。字典是由关键字两部分组成,也就是 key 和 value,中间用冒号分隔。这种结构类似于新华字典,字典中每一个字都有一个对应的解释,具体的用法是这样的:

    字典名 = {关键字1:值,关键字2:值,关键字3:值}

    注:

     

      1)键是唯一的,创建第二个同名键的时候,第二个同名键会覆盖第一个同名键,即不允许出现两个相同的键;

     

      2)键是不可变的,不能用列表当键。

     

    eg:

    # 构建一个字典,记录各个教师的收入
    name_money = {'王老师':30000,'侯老师':28000,'李老师':33000,'张老师':25000}
    print(name_money)
    print('字典的数据类型表示是:',type(name_money))

      结果是:

    {'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000}
    字典的数据类型表示是: <class 'dict'>

      字典的基本操作:

      常见的字典操作是访问字典、遍历字典等,实际项目中经常被使用到,比如 excel 文件读入内存以后,按照字典的方法存放,然后对其增删值。

      访问字典:

      访问字典也就是获取关键字对应的值,方法是指定字典名和放在方括号内的关键字,获取后的值可以赋值给变量。

      eg:

    Teacher_Li = name_money['李老师']
    print(f'李老师的月薪是:{Teacher_Li}元/月')

      结果是:

    李老师的月薪是:33000元/月

      添加、修改、删除键值对:

      字典是一种可变的数据结构,可以随时添加或者删除其中的键值对。方法是,指定字典名、用方括号括起的键和相关的值。

      eg:

    print(f'原来老师们的月薪情况是:{name_money}')
    # 新来了熊老师和陈老师,他们的月薪如下:
    name_money['熊老师'] = 15000
    name_money['陈老师'] = 50000
    print(f'新来老师后,老师们的月薪情况是:{name_money}')
    # 熊老师因为研究突破,所以工资涨了5000块,变成了20000
    name_money['熊老师'] = 15000 + 5000
    print(f'熊老师加薪后,老师们的月薪情况是:{name_money}')
    # 李老师因为个人原因,离开了学校
    del name_money['李老师']
    print(f'李老师走后,老师们的月薪情况是:{name_money}')

      结果是:

    原来老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000}
    新来老师后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000, '熊老师': 15000, '陈老师': 50000}
    熊老师加薪后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '李老师': 33000, '张老师': 25000, '熊老师': 20000, '陈老师': 50000}
    李老师走后,老师们的月薪情况是:{'王老师': 30000, '侯老师': 28000, '张老师': 25000, '熊老师': 20000, '陈老师': 50000}

      创建空字典:

      在实际项目中,我们可能不知道字典中存放的内容是什么。这时,我们可以采用从空的字典开始动态创建,也就是在程序运行的时候添加具体的内容。

      常见的使用场景是:第一个:需要用户输入数据存储为字典;第二个是自动生成大量的键值对,比如爬虫,爬取豆瓣电影的排名信息。我们可以把排名放入空的字典中,然后每次爬取一个电影, 添加一个对应的键值对。

    # 从空的字典开始创建
    student_info = {} # 定义空的字典
    student_info['姓名'] = '胡晓明'
    student_info['学号'] = 201811131123
    student_info['专业'] = '信息与科学技术'
    student_info['班级'] = '一班'
    print('从空的列表中构建字典:',student_info)

      结果是:

    从空的列表中构建字典: {'姓名': '胡晓明', '学号': 201811131123, '专业': '信息与科学技术', '班级': '一班'}

      字典的内置函数

    # 内置函数
    # 内置函数cmp()的替代方法
    import operator as op op.lt('王老师','刘老师') # 相当与'王老师'<'张老师' op.le('王老师','张老师') # 相当于'王老师'<='张老师' op.eq('王老师','张老师') # 相当于'王老师'=='张老师' op.ne('王老师','张老师') # 相当于'王老师'!='张老师' op.gt('王老师','张老师') # 相当于'王老师'>'张老师' op.ge('王老师','张老师') # 相当于 '王老师'>='张老师' # 计算字典元素个数,即键的总数。 len(name_money) # 输出字典可打印的字符串表示。 str(name_money) # 内置方法 name_money1 = name_money.copy() # 复制字典 name_money1.clear() # 删除字典 name_money1['刘老师'] = 32000 name_money.fromkeys([1,3,4],'') # 创建一个新字典,其中前一个参数序列为键,后一个参数为值,适用于批量产生多个同值得键 name_money.get('王老师',None) # 获取对应键的值,如果没有该键,则返回参数2 name_money.setdefault('张老师', None) #获取对应键的值,如果没有该键,则在原字典里添加上该键值对,值为参数2 '熊老师' in name_money # 判断键是否在字典中 name_money.items() # 元组形式存储字典 name_money.keys() # 返回所有的键 name_money.values() # 返回所有的值 name_money.update(name_money1) # 合并两个字典的键值对

    字典与列表结合:

    把一系列字典存储在列表中,或将列表作为值放在字典中,这称为嵌套。你可以在列表中嵌套字典、在字典中嵌套列表甚至在字典中嵌套字典。这在项目中经常用到。

    什么时候用列表什么时候用字典呢? 

    当你存取的数据类型一样时,使用列表,当你存取的数据类型不一样时就用字典。

    注:数据类型不一样不是指整形或者字符型。

    举个例子:如果你需要存很多人的姓名,仅仅这一个属性,就用列表来进行处理,当你要存取不仅仅是人名,包括年龄,性别,国籍等等这些信息时,这时候用字典是最合适的。 

    字典列表

    # 合并两个字典,每个字典存为一个元素
    la = [name_money1,name_money]

      在字典中存储列表

    # 在字典中存放列表
    family = {'小米':['小米8','小米note'],'华为':['华为P20','荣耀9'],'苹果':['iphone8','iphoneX']}
    print(family)
    
    # 上述代码的运行结果是:
    # {'小米': ['小米8', '小米note'], '华为': ['华为P20', '荣耀9'], '苹果': ['iphone8', 'iphoneX']}

      在字典中存储字典

    # 在字典中存储字典
    phone = {'小米':{'小米8':3000,'小米note':5000},'华为':{'华为P20':3300,'荣耀9':2055},'苹果':{'iphone8':8000,'iphoneX':12000}}
    print(phone)
    # 找出虾米
    print(phone['小米']['小米8'])
    
    # 以上代码输出的结果是:
    # {'小米': {'小米8': 3000, '小米note': 5000}, '华为': {'华为P20': 3300, '荣耀9': 2055}, '苹果': {'iphone8': 8000, 'iphoneX': 12000}}
    # 3000

      小小的项目练习

    # 《扶摇》演员表的小练习
    # 创建一个字典存放演员信息
    Fuyao_Actor_Profile = {'杨幂':{'角色':'扶摇','配音演员':'王潇倩'},'阮经天':{'角色':'长孙无极','配音演员':'马正阳'},'刘奕君':{'角色':'齐震','配音演员':'刘奕君'},'高伟光':{'角色':'战北野','配音演员':'赵成晨'},'王劲松':{'角色':'长孙迥','配音演员':'王劲松'},'黄宥明':{'角色':'燕惊尘','配音演员':'文森'},'高瀚宇':{'角色':'江枫','配音演员':'袁聪宇'},'顾又铭':{'角色':'战北恒','配音演员':'林强'},'秦焰':{'角色':'周叔','配音演员':'宣晓鸣'},'蒋龙':{'角色':'小七','配音演员':'苏尚卿'}}
    # 打印出杨幂扮演的角色
    print(f'杨幂扮演的角色是:{Fuyao_Actor_Profile["杨幂"]["角色"]}')
    # 创建一个备份字典,备份演员信息表
    Copy_Fuyao = Fuyao_Actor_Profile.copy()
    
    # 删去阮经天的演员表
    del Fuyao_Actor_Profile['阮经天']
    print(f'删去阮经天后的演员表为:{Fuyao_Actor_Profile}')
    # 更换为演员陈晓
    Fuyao_Actor_Profile['陈晓'] = {'角色':'长孙无极','配音演员':'马正阳'}
    print(f'阮经天换为陈晓后的演员表为:{Fuyao_Actor_Profile}')
    
    # 新增加角色
    Fuyao_Actor_Profile['张雅钦'] = {'角色':'雅兰珠','配音演员':'吟良犬'}
    Fuyao_Actor_Profile['王鹤润'] = {'角色':'凤净梵','配音演员':'蔡娜'}
    Fuyao_Actor_Profile['周俐葳'] = {'角色':'时岚','配音演员':'张晗'}
    Fuyao_Actor_Profile['魏晖倪'] = {'角色':'简雪','配音演员':'曹一茜'}
    
    # 打印出阮经天所在的演员表里的演员名
    print(f'阮经天所在的演员表里的演员名:{Copy_Fuyao.keys()}')
    # 打印出阮经天所在的演员表里的角色名,并统计一共有多少个演员
    print('阮经天所在的演员表里的角色名:')
    for i in Copy_Fuyao.keys():
        print(f'{Copy_Fuyao[i]["角色"]}')
    print(f'一共有{len(Copy_Fuyao)}个角色')  
    # 扶摇的详细细节
    Fuyao_Actor_Profile.fromkeys(['杨幂'],{'名字':'扶摇','喜欢的男角色':['长孙无极','战北野','小七'],'去过的国家':['太渊','天权','天煞','璇玑']})

      

  • 相关阅读:
    core mvc 分页
    core下的routelink
    python 3使用binascii方法的报错解决
    汉字乱码处理
    DLL的调用方法
    Python内置函数清单
    Linux 几种上传文件到linux服务的方法
    在VS中添加lib的第三种方法
    Bash Shell 数字/字符比较大小
    虚拟Linux服务器不能获取IP的解决办法
  • 原文地址:https://www.cnblogs.com/HYLering/p/9992856.html
Copyright © 2020-2023  润新知