2.23总结-字典、作业

2.23总结-字典、作业

1.认识字典(dict)

  1. 是容器型数据类型;将{}作为容器的标志,里面多个键值对用逗号隔开:{键1:值1,键2:值2,键3:值3,…}
    键值对: 键:值

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

  3. 对元素的要求
    字典的元素是键值对
    a.键的要求:键必须是不可变的类型的数据(数据、字符串、布尔、元组等);键是唯一的
    b.值的要求:没有要求

2.查 - 获取字典的值

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

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

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

  2. 遍历

    1)直接遍历
    for 键 in 字典:
    pass

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

  3. 增、改 - 添加键值对

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

    del 字典[键] - 删除指定键对应的键值对
    字典.pop(键) - 取出指定键对应的值

  5. 相关操作

    1)运算符:字典不支持:+、*、>、<、>=、<= ,只支持 == 、!=
    2)in 和 not in - 字典的in和not in 操作判断的是字典中是否存在指定的键
    键 in 字典

    3)相关函数:len 、 dict

    len(字典) - 获取字典中键值对的个数

    dict(数据) - 将指定数据转换成字典
    对数据的要求:1.数据本身是一个序列
    2.序列中的元素必须都是有且只有两个元素的小序列,并且其中第一个元素是不可变的数据

    4)相关方法

    a. 字典.clear()
    b. 字典.copy()
    c.
    字典.keys() - 返回一个序列,序列中元素是字典所有的键
    字典.values() - 返回一个序列,序列中元素是字典所有的值
    字典.items() - 返回一个序列,序列中元素是由键和值组成的元组

    d. update
    字典.update(序列) - 将序列中的元素全部添加到字典中(序列必须是可以转换成字典的序列)
    字典1.update(字典2) - 将字典2中所有的键值对都添加到字典1中

6.字典推导式

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

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

作业

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

    dict1 = {
        'name': '小明',
        'age': 18,
        'score': 66,
        'tel': '15579927163',
        'gender': '男'
    }
    
  2. 定义一个列表,在列表中保存6个学生的信息(学生信息中包括: 姓名、年龄、成绩(单科)、电话、性别(男、女、不明) )

    stu = [
            {'name': '小明', 'age': 18, 'score': 100, 'tel': '132456', 'gender': '男'},
            {'name': '小花', 'age': 25, 'score': 98,  'tel': '132874', 'gender': '女'},
            {'name': '张三', 'age': 34, 'score': 90,  'tel': '123428', 'gender': '男'},
            {'name': '李四', 'age': 18, 'score': 70,  'tel': '947322', 'gender': '性别不明'},
            {'name': '王二', 'age': 19, 'score': 55,  'tel': '346741', 'gender': '男'},
            {'name': '赵敏', 'age': 18, 'score': 99,  'tel': '473669', 'gender': '女'},
            {'name': '老王', 'age': 16, 'score': 43,  'tel': '132124', 'gender': '男'}
    ]
    print(stu)
    
    1. 统计不及格学生的个数

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

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

      otal_age = 0
      for i in stu:
          total_age += i['age']
      print(total_age/len(stu))
      
    4. 打印手机尾号是8的学生的名字

      name1 = [i['name'] for i in stu if i['tel'][-1] == '8']
      print(name1)
      
    5. 打印最高分和对应的学生的名字

      max_score = stu[0]['score']
      max_name = [stu[0]['name']]
      for i in stu[1:]:
          if i['score'] > max_score:
              max_score = i['score']
              max_name.clear()
              max_name.append(i['name'])
          elif i['score'] == max_score:
              max_name.append(i['name'])
      print(max_score, max_name)
      
    6. 删除性别不明的所有学生

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

      list1 =[stu[0]]
      for i in stu[1:]:
          for index, item in enumerate(list1):
              print(index, item)
              if i['score'] >= item['score']:
                  list1.insert(index, i)
                  break
          else:
              list1.append(i)
      print(list1)
      
  3. 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)

    class1 = {
        'class_name': 'python2201',
        'address': '12教室',
        'class_teacher': {'name': '张瑞燕', 'gender': '女', 'tel': '1221421'},
        'lecturer': {'name': '余婷', 'gender': '女', 'tel': '13678192302'},
        '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': 95, '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. 利用列表推导式获取所有狗的品种

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

      breed1 = [dog['breed'] for dog in dogs]
      print(breed1)
      
    2. 利用列表推导式获取所有白色狗的名字

      [‘贝贝’, ‘可乐’]

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

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

      count1 = len([dog for dog in dogs if dog['breed'] == '银狐'])
      print(count1)
      
上一篇:u-boot lists_bind_fdt函数


下一篇:AngularJs开发——指令与控制器间的通信