day7-字典作业

day 7 学习笔记

认识字典

(1)字典是容器型数据类型

(2)字典是可变的(支持增删改);字典是无序的(不支持下标操作)

(3) 元素的要求:

​ a. 键:键必须是不可变的数据类型的数据;键是唯一的

​ b. 值:没有要求

字典的查操作

(1)查单个

字典[键]

字典.get(键)

字典.get(键, 默认值)

(2) 遍历

for 变量 in 字典:

​ 循环体

字典的增删改操作

1.增、改

语法1:字典[键] = 值 - 如果键不存在就添加键值对;如果键存在就修改指定键对应的值

语法2:字典.setdefault(键, 值) - 增加键值对

2.删除

(1)del 字典[键] - 删除指定键对应的值

(2)字典.pop(‘键’) - 取出指定键对应的值

字典的相关操作和方法

1.字典的相关操作: in 和 not in

字典不支持+、*、比较大小

2.字典相关函数:len、dict

3.字典相关方法:字典.方法()

字典推导式

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

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

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

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

    1. 统计不及格学生的个数

    2. 打印不及格未成年学生的名字和对应的成绩

    3. 求所有男生的平均年龄

    4. 打印手机尾号是8的学生的名字

    5. 打印最高分和对应的学生的名字

    6. 删除性别不明的所有学生

    7. 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)

      students = [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男'},
                  {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '不明'},
                  {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女'},
                  {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男'},
                  {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女'},
                  {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男'}
                  ]
      # 1. 统计不及格学生的个数
      count = 0
      for stu in students:
          if stu['score'] < 60:
              count += 1
      print('不及格人数为:', count)
      
      # 2. 打印不及格未成年学生的名字和对应的成绩
      for stu in students:
          if stu['score'] < 60 and stu['age'] < 18:
              print(stu['name'], stu['score'])
      
      # 3. 求所有男生的平均年龄
      sum_age = 0
      count = 0
      for stu in students:
          if stu['gender'] == '男':
              count += 1
              sum_age += stu['age']
      print('男生平均年龄为:', sum_age // count)
      
      # 4. 打印手机尾号是8的学生的名字
      print('手机尾号为8的学生有:')
      for stu in students:
          if list(stu['tel'])[-1] == '8':
              print(stu['name'])
      
      # 5. 打印最高分和对应的学生的名字
      max_score = students[0]['score']
      i = 0
      for index, stu in enumerate(students):
          if stu['score'] > max_score:
              max_score = stu['score']
              i = index
      print('最高分为:', max_score, '获得最高分的学生为:', students[i]['name'])
      
      # 6. 删除性别不明的所有学生
      for index, stu in enumerate(students):
          if stu['gender'] == '不明':
              del students[index]
      print(students)
      
      # 7. 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃)
      students = [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男'},
                  {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '不明'},
                  {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女'},
                  {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男'},
                  {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女'},
                  {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男'}
                  ]
      
      # 冒泡排序的方法
      n = len(students)
      for j in range(0, n - 1):
          for i in range(0, n - 1 - j):
              if students[i]['score'] < students[i + 1]['score']:
                  students[i], students[i + 1] = students[i + 1], students[i]
      print(students)
      
      # 方法二
      new_students = []
      max_score = 0
      i = 0
      while students:
          for index, stu in enumerate(students):
              if stu['score'] > max_score:
                  max_score = stu['score']
                  i = index
          s = students.pop(i)
          new_students.append(s)
          max_score = 0
          i = 0
      print(new_students)
      
  3. 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)

    class1 = {
        'name': 'Python 2202',
        'address': '14',
        'head_teacher': {'name': '舒玲', 'age': '18', 'gender': '女', 'tel': '1564621'},
        'lecture': {'name': '余婷', 'age': 18, 'gender': '女', 'tel': '7789414'},
        'students': [{'name': '小明', 'age': 21, 'score': 91, 'tel': '1235418', 'gender': '男', 'major': '电子信息'},
                     {'name': '小辉', 'age': 17, 'score': 87, 'tel': '4515121', 'gender': '男', 'major': '数学'},
                     {'name': '小红', 'age': 20, 'score': 79, 'tel': '5512144', 'gender': '女', 'major': '会计'},
                     {'name': '小蓝', 'age': 16, 'score': 54, 'tel': '1245178', 'gender': '男', 'major': '计算机'},
                     {'name': '小紫', 'age': 25, 'score': 92, 'tel': '9881112', 'gender': '女', 'major': '数学'},
                     {'name': '小白', 'age': 24, 'score': 59, 'tel': '4131544', 'gender': '男', 'major': '电子信息'}
                     ]
    }
    
  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. 利用列表推导式获取所有狗的品种

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

    2. 利用列表推导式获取所有白色狗的名字

      [‘贝贝’, ‘可乐’]

    3. 给dogs中没有性别的狗添加性别为 ‘公’

    4. 统计 ‘银狐’ 的数量

      # 1. 利用列表推导式获取所有狗的品种
      #    > ['银狐',  '法斗', '土狗',  '哈士奇',  '银狐',  '土狗']
      
      dogs_breed = [dog['breed'] for dog in dogs]
      print(dogs_breed)
      
      # 2. 利用列表推导式获取所有白色狗的名字
      #    > ['贝贝', '可乐']
      
      dogs_name = [dog['name'] for dog in dogs if dog['color'] == '白色']
      print(dogs_name)
      
      # 3. 给dogs中没有性别的狗添加性别为 '公'
      
      for dog in dogs:
          dog.setdefault('gender', '公')
      print(dogs)
      
      # 4. 统计 ‘银狐’ 的数量
      count = 0
      for dog in dogs:
          if dog['breed'] == '银狐':
              count += 1
      print('银狐的数量为:', count)
      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值