day19 练习

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

with open(r'D:\cool\user','rt',encoding='utf-8')as f:
    l = [dict(zip(['name','sex','age','salary'],x.strip().split(' '))) for x in f]

print(l)

# 2 根据1得到的列表,取出所有人的薪资之和

l1=sum(int(y['salary'])for y in l)
print(l1)


# 3 根据1得到的列表,取出所有的男人的名字
l2=[y['name'] for y in l if y['sex']=='male']
print(l2)




# 4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
l3=[ y.update({'name':y['name'].capitalize()}) for y in l ]
print(l3)


# 5 根据1得到的列表,过滤掉名字以a开头的人的信息
l4=[ y for y in l if not y['name'].startswith('a')]  ???
print(l4)


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

def f1(x,y):
    z=x+y
    print(x)
    f1(y,z)

f1(0,1)


# 7 一个嵌套很多层的列表,如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 f1(l1):
    for x in l1:
        if type(x) is list:
            f1(x)
        else:
            print(x)
f1(l)

 

posted @ 2020-03-25 22:11  It's_cool  阅读(106)  评论(0)    收藏  举报