Fork me on GitHub

day-14 作业

作业

  1. 文件内容如下,标题为:姓名,性别,年纪,薪资
egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000

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

# 按要求生成列表
lt1 = ['name', 'sex', 'age', 'salary']
info_lt = []
with open('info.txt', 'r', encoding='utf-8')as fr:
    for line in fr.readlines():
        # print(line)
        data = line.strip().split(' ')
        # print(data)
        dic = {k: v for k, v in zip(lt1, data)}
        info_lt.append(dic)
  1. 根据1得到的列表,取出薪资最高的人的信息

    print(max(info_lt, key=lambda dic: dic['salary']))
    
  2. 根据1得到的列表,取出最年轻的人的信息

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

    res = list(map(lambda dic: dic['name'].title(), info_lt))
    
    for i in range(len(res)):
        info_lt[i]['name'] = res[i]
    
  4. 根据1得到的列表,过滤掉名字以a开头的人的信息

    res = list(filter(lambda dic: not dic['name'].startswith('a'), info_lt))
    
  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]]]]]]],用递归取出所有的值

    l = [1, 2, [3, [4, 5, 6, [7, 8, [9, 10, [11, 12, 13, [14, 15]]]]]]]
    
    
    def bianli(l):
        for i in l:
            if isinstance(i, list):
                bianli(i)
            else:
                print(i)
    
posted @ 2019-09-25 19:33  Yugaliii  阅读(82)  评论(0编辑  收藏  举报