• day14


    文件内容如下,标题为:姓名,性别,年纪,薪资

    egon male 18 3000
    alex male 38 30000
    wupeiqi female 28 20000
    yuanhao female 28 10000
    

    要求:
    从文件中取出每一条记录放入列表中,列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式

    1. 根据1得到的列表,取出薪资最高的人的信息

      salary_dict = {
          'egon': 3000,
          'alex': 30000,
          'wupeiqi': 20000,
          'yuanhao': 10000
      }
      
      print(f"max(salary_dict): {max(salary_dict)}")
      
      
      def func(k):
          return salary_dict[k]
      
      
      print(f"max(salary_dict, key=func()): {max(salary_dict, key=func)}")
      # 'egon', v1 = func('egon')
      # 'alex', v2 = func('alex')
      # 'wupeiqi v3 = func('wupeiqik')
      # 'yuanhao', v4 = func('yuanhao')
      
      
      print(
          f"max(salary_dict, key=lambda name: salary_dict[name]): {max(salary_dict, key=lambda name: salary_dict[name])}")
      
      
    2. 根据1得到的列表,取出最年轻的人的信息

      
      print(min(mylist, key=lambda x:x['age']))
      
    3. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式

      res = max(salary_dict, key=func)  # 默认key的首字母
      res = max(salary_dict, key=lambda name: salary_dict[name])  # 默认key的首字母
       print(res)
      
    4. 根据1得到的列表,过滤掉名字以a开头的人的信息

      res = filter(lambda x:x['name'][0]!='a',mylist)
      print(list(res))
      
    5. 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)

      def fib(n):
          if n == 1 or n == 2:
              return 1
          else:
              return fib(n - 1) + fib(n - 2)
      
    6. 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值

  • 相关阅读:
    Trap 冷启动与热启动告警
    SNMP支持IPv6
    跨函数使用内存
    动态内存分配
    结构体
    指针和数组
    组合模式
    类方法实用点语法调用
    数据结构与算法定义
    RAC初步使用
  • 原文地址:https://www.cnblogs.com/TZ0503/p/11586930.html
Copyright © 2020-2023  润新知