day8-字典和作业

day8总结

  • 认识字典
  • 字典的基本操作
  • 字典的增删改
  • 字典相关操作函数和方法
  • 字典推导式(了解)
一、认识字典
  1. 字典和列表的选择:

    需要同时保存多个数据的时候,如果多个数据的意义相同(不需要区分)就使用列表,如果多个数据的意思不同就用字典。

  2. 认识字典(dict)

    a. 是容器型数据类型:

    将{}作为容器的标志,里面多个键值对 用逗号隔开:{键1:值1,键2:值2…}

    键值对的格式:键:值

    b. 特点

    字典是可变的(支持增删改);字典是无序(不支持下标,元素顺序不影响结果)

    c. 对元素的要求

    键:键是不可变类型的数据(数字、字符串、布尔、元祖等) 键是唯一的

    值:值没有要求

    # 空字典
    dict1 = {}
    
    # 字典中的元素只能是键值对
    dict2 = {'name': '小明', 'age': 20}
    print(dict2)
    # dict3 = {'name': '张三', 30}        # 报错! 30不是键值对
    
    # 字典无序
    print({'a': 10, 'b': 20} == {'b': 20, 'a': 10})         # True
    
    # 键是不可变类型的数据
    dict3 = {10: 23, 1.23: 10, 'abc': 30, (1, 2): 50}
    print(dict3)
    
    # dict4 = {10: 23, 1.23: 10, 'abc': 30, [1, 2]: 50}   # 报错!
    
    # 键是唯一
    dict4 = {'a': 10, 'b': 20, 'c': 30, 'a': 100}
    print(dict4)        # {'a': 100, 'b': 20, 'c': 30}
    
二、字典的基本操作
  1. 查 - 获取字典的值

    查单个(重要) - 一次获取一个值

    “”"
    语法1:字典[键] - 获取字典中指定键对应的值; 如果键不存在会报错!

    语法2:
    字典.get(键) - 获取字典中指定键对应的值; 如果键不存在不会报错,并且返回None
    字典.get(键, 默认值) - 获取字典中指定键对应的值; 如果键不存在不会报错,并且返回默认值
    “”"

  2. 遍历

    for 键 in 字典:

    for 键,值 in 字典.items():

三、字典的增删改
  1. 增/改 - 添加键值对

    """
    1) 字典[键] = 值       如果键存在就修改指定键对应的值;如果键不存在就添加键值对
    
    2) 字典.setdefault(键, 值)     添加键值对(如果键不存在就添加键值对,如果键存在不动字典)
    """
    
  2. 删 - 删除键值对 (了解)

    """
    del 字典[键]       -       删除指定键对应的键值对
    字典.pop(键)       -       取出指定键对应的值
    """
    
四、字典相关操作函数和方法
  1. 相关操作

    运算符:字典不支持 +、*、>、<、>=、<=,只支持 == 、!=

    in 和 not in - 字典的in和not in操作判断的是字典中是否存在指定的键

  2. 相关函数: len、dict

    """
    a. len(字典)  -  获取字典中键值对的个数
    
    b. dict(数据)  -  将指定数据转换成字典
    对数据的要求:1. 数据本身是一个序列
                2. 序列中的元素必须都是有且只有两个元素的小序列,并且其中第一个元素是不可变的数据
    """
    
  3. 相关方法

    字典.clear()

    字典.copy()

    字典.keys() - 返回一个序列,序列中的元素是字典所有的键

    字典.values() - 返回一个序列,序列中的元素是字典所有的值

    字典.items() - 返回一个序列,序列中的元素是由每一对键和值组成的元组

    字典.update(序列) - 将可以序列中的元素全部添加字典中(序列必须是可以转换成字典的序列)

    字典1.update(字典2) - 将字典2中所有的键值对都添加到字典1中

五、字典推导式
  1. 字典推导式

    {表达式1:表达式2 for 变量 in 序列}

    {表达式1:表达式2 for 变量 in 序列 if 条件语句}

    result = {x: x*2 for x in range(5)}
    print(result)
    
    result = {x: x for x in range(10) if x % 3}
    print(result)
    

作业

  1. 定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别

    stu = {'name': '大司马', 'age': '35', 'mark': '100分', 'tel': '182000000', 'sex': '男'}
    
  2. 定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )

    stu = [
            {'name': '大司马', 'gender': '男', 'age': 18, 'score': 100, 'tel': '1811231'},
            {'name': '酥酥', 'gender': '女', 'age': 20, 'score': 98, 'tel': '1811232'},
            {'name': 'theshy', 'gender': '男', 'age': 32, 'score': 90, 'tel': '1811233'},
            {'name': '余霜', 'gender': '女', 'age': 22, 'score': 70, 'tel': '1811234'},
            {'name': '管泽元', 'gender': '男', 'age': 28, 'score': 100, 'tel': '1811235'},
            {'name': '洛丽塔', 'gender': '不明', 'age': 17, 'score': 99, 'tel': '1811238'},
        ]
    
    1. 统计不及格学生的个数

      count = 0
      for x in stu:
          if x['score'] < 60:
              count += 1
      print('不及格学生的个数:', count)
      
    2. 打印不及格未成年学生的名字和对应的成绩

      result = 0
      for x in stu:
          if x['score'] < 60 and x['age'] < 18:
              result = x['name']
      print(result, x['score'])
      
    3. 求所有男生的平均年龄

      result = 0
      count = 0
      for x in stu:
          if x['gender'] == '男':
              result += x['age']
              count += 1
      print('平均年龄:', result / count)
      
    4. 打印手机尾号是8的学生的名字

      result = 0
      for x in stu:
          if int(x['tel']) % 10 == 8:
              result = x['name']
      print(result)
      
    5. 打印最高分和对应的学生的名字

      max_score = max(stu1['score'] for stu1 in stu)
      names = [stu1['name'] for stu1 in stu if stu1['score'] == max_score]
      print(names,max_score)
      
    6. 删除性别不明的所有学生

      result=[]
      for x in stu:
          if x['gender'] != '不明':
              result.append(x)
      print(result)
      
    7. 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)

  3. 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)

    class12 = {    'name': 'python2201',    'address': '12教室',    'lecturer': {        'name': '余婷',        'gender': '女',        'age': 20,        'tel': '13678192302'    },    'class_teacher': {        'name': '张瑞燕',        'gender': '女',        'tel': '110',        'age': 20,        'QQ': '617818271'    },    'students': [        {'name': '大司马', 'gender': '男', 'age': 18, 'score': 100, 'education': '专科', 'linkman': {'name': '小吴', 'tel': '110'}},        {'name': '酥酥', 'gender': '女', 'age': 20, 'score': 98, 'education': '本科', 'linkman': {'name': '小张', 'tel': '120'}},        {'name': '肉鸡', 'gender': '男', 'age': 30, 'score': 90, 'education': '本科', 'linkman': {'name': '小赵', 'tel': '119'}},        {'name': '羞男', 'gender': '男', 'age': 22, 'score': 70, 'education': '专科', 'linkman': {'name': '小刘', 'tel': '134'}},        {'name': '小明', 'gender': '男', 'age': 28, 'score': 100, 'education': '本科', 'linkman': {'name': '小徐', 'tel': '2383'}},        {'name': '余霜', 'gender': '女', 'age': 27, 'score': 99, 'education': '专科', 'linkman': {'name': '小胡', 'tel': '23423'}},        {'name': '老王', 'gender': '男', 'age': 22, 'score': 89, 'education': '本科', 'linkman': {'name': '小王', 'tel': '1234'}}    ]}
    
  4. 已知一个列表保存了多个狗对应的字典:

    dogs = [  {'name': '贝贝', 'color': '白色', 'breed': '银狐', 'age': 3, 'gender': '母'},  {'name': '花花', 'color': '灰色', 'breed': '法斗', 'age': 2},  {'name': '财财', 'color': '黑色', 'breed': '土狗', 'age': 5, 'gender': '公'},  {'name': '包子', 'color': '黄色', 'breed': '哈士奇', 'age': 1},  {'name': '可乐', 'color': '白色', 'breed': '银狐', 'age': 2},  {'name': '旺财', 'color': '黄色', 'breed': '土狗', 'age': 2, 'gender': '母'}]
    
    1. 利用列表推导式获取所有狗的品种

      [‘银狐’, ‘法斗’, ‘土狗’, ‘哈士奇’, ‘银狐’, ‘土狗’]

      result = [x['breed'] for x in dogs]result = {x: x for x in range(10) if x % 3}print(result)
      
    2. 利用列表推导式获取所有白色狗的名字

      [‘贝贝’, ‘可乐’]

      result = [x['name'] for x in dogs if x['color'] == '白色']print(result)
      
    3. 给dogs中没有性别的狗添加性别为 ‘公’

      for x in dogs:    x.setdefault('gender', '公')print(dogs)
      
    4. 统计 ‘银狐’ 的数量

      count = 0for x in dogs:    if x['breed'] == '银狐':        count += 1print(count)
      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值