不大不白的输出

  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}的形式

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

  2. 根据1得到的列表,取出最年轻的人的信息

  3. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式

  4. 根据1得到的列表,过滤掉名字以a开头的人的信息

  5. 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)

  6. 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值

with open('wdnmd.txt', 'w', encoding='utf8')as fw:
    fw.write('''egon male 18 3000  
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000
''')  # 这里注意不要有空
lis1 = ['name', 'gender', 'age', 'salary']
res = []
with open('wdnmd.txt', 'r', encoding='utf8')as fr:
    for line in fr:
        line = line.strip()
        lis = line.split()
        dic = {k: v for k, v in zip(lis1, lis)}
        res.append((dic))
print(res)

# 首先得导入进去
hightest = max(res, key=lambda salary: salary['salary'])
print(hightest)

lowest = min(res, key=lambda age: age['age'])
print(lowest)

# 3. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
# 映射就是map

maps = map(lambda item: {'name': item['name'].capitalize()}, res)
print(list(maps))

# 根据1得到的列表,过滤掉名字以a开头的人的信息
# a法表示过意不去,觉得很开心
res = filter(lambda x: x['name'][0] != 'a', res)
print(list(res))


# 斐波那契数列
# 百度了一下啥是斐波那契数列
def fibo(n):
    if n <= 1:
        return n
    else:
        return (fibo(n - 1) + fibo(n - 2))
inputNUM = int(input("您要输出几项? "))
if inputNUM <= 0:
    print("我日你🐎,输入正数可以吗")
else:
    for i in range(inputNUM):
        print(fibo(i))

posted @ 2019-09-25 20:16  是我,米老鼠  阅读(189)  评论(0编辑  收藏  举报