day8字典作业

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

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

    # 定义一个变量保存一个学生的信息,学生信心中包括:姓名、年龄、成绩(单科)、电话、性别
    stu1 = [
        {'name': '鲁班', 'age': 17, 'results': 87, 'tel': '646203', 'gender': '男'},
        {'name': '张良', 'age': 41, 'results': 76, 'tel': '178456', 'gender': '男'},
        {'name': '妲己', 'age': 23, 'results': 82, 'tel': '646215', 'gender': '女'},
        {'name': '貂蝉', 'age': 34, 'results': 99, 'tel': '164299', 'gender': '女'},
        {'name': '墨子', 'age': 94, 'results': 43, 'tel': '9090900', 'gender': '不明'},
        {'name': '沈孟溪', 'age': 194, 'results': 73, 'tel': '54288', 'gender': '不明'},
    
    ]
    # 1. 统计不及格学生的个数
    list_stu1 = [i for i in stu1 if i['results']<=60]
    print(len(list_stu1))
    
    # 2. 打印不及格未成年学生的名字和对应的成绩
    for i in stu1:
        if i['age']<=18 or i['results']<=60:
            print(i['name'],i['results'])
            
    # 3. 求所有男生的平均年龄
    nums =count1 =0
    for i in stu1:
        if i['gender'] =='男':
            nums+=i['age']
            count1 +=1
    print(nums/count1)
    
    # 4. 打印手机尾号是8的学生的名字
    for i in stu1:
        if i['tel'][-1] =='8':
            print(i['name'])
    
    # 5. 打印最高分和对应的学生的名字
    list_results =[i['results'] for i in stu1]
    for i in stu1:
        if i['results'] == max(list_results):
            print(i['name'],'最高分是',max(list_results),sep='')
    
    # 6. 删除性别不明的所有学生
    for i in range(len(stu1)-1,-1,-1):
        if stu1[i]['gender'] =='不明':
            stu1.remove(stu1[i])
            
    # 7. 将列表按学生成绩从大到小排序(挣扎一下,不行就放弃
    stu1 = [
        {'name': '鲁班', 'age': 17, 'results': 87, 'tel': '646203', 'gender': '男'},
        {'name': '张良', 'age': 41, 'results': 76, 'tel': '178456', 'gender': '男'},
        {'name': '妲己', 'age': 23, 'results': 82, 'tel': '646215', 'gender': '女'},
        {'name': '貂蝉', 'age': 34, 'results': 99, 'tel': '164299', 'gender': '女'},
        {'name': '墨子', 'age': 94, 'results': 43, 'tel': '9090900', 'gender': '不明'},
        {'name': '沈孟溪', 'age': 194, 'results': 73, 'tel': '54288', 'gender': '不明'},
    
    ]
    for i in range(len(stu1)-1):
        for j in range(i+1,len(stu1)):
            if stu1[i]['results'] < stu1[j]['results']:
                stu1[i],stu1[j]=stu1[j],stu1[i]
    print(stu1)
    
  3. 定义一个变量保存一个班级的信息,班级信息中包括:班级名称、教室位置、班主任信息、讲师信息、班级所有的学生(根据实际情况确定数据类型和具体信息)

    class_text ={'classname':'python2204','location':'15教',
                 'classteacher':{'name':'静姐','age':'19','tel':'456'},
                 'teacher':[
                     {'name':'付哥','age':24,'tel':'12345'},
                     {'name':'婷姐','age':18,'tel':'75689'},
                     {'name':'骆神','age':26,'tel':'987654'}],
                 'classstu':stu1 = [
        {'name': '鲁班', 'age': 17, 'results': 87, 'tel': '646203', 'gender': '男'},
        {'name': '张良', 'age': 41, 'results': 76, 'tel': '178456', 'gender': '男'},
        {'name': '妲己', 'age': 23, 'results': 82, 'tel': '646215', 'gender': '女'},
        {'name': '貂蝉', 'age': 34, 'results': 99, 'tel': '164299', 'gender': '女'},
        {'name': '墨子', 'age': 94, 'results': 43, 'tel': '9090900', 'gender': '不明'},
        {'name': '沈孟溪', 'age': 194, 'results': 73, 'tel': '54288', 'gender': '不明'},
    
    ]
                 }
    
  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. 利用列表推导式获取所有狗的品种

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

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

      [‘贝贝’, ‘可乐’]

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

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Zack_36

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值