data = '''egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000'''
with open('作业_14.txt','w',encoding='utf8') as fw:
fw.write(data)
#1.从文件中取出每一条记录放入列表中,列表的每个元素都是`{'name':'egon','sex':'male','age':18,'salary':3000}`的形式
lt1 = []
title = ['name','sex','age','salary']
with open('作业_14.txt','r',encoding='utf8') as fr:
for i in fr:
lti = i.strip().split(' ')
dici = {m:n for m,n in zip(title,lti)}
lt1.append(dici)
print(lt1)
#2.根据1得到的列表,取出薪资最高的人的信息
res1 = max(lt1,key=lambda i:i[title[-1]])
print(res1)
#3.根据1得到的列表,取出最年轻的人的信息
res2 = min(lt1,key=lambda i:i[title[2]])
print(res2)
#4.根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
res3 = list(map(lambda i:i[title[0]].title(),lt1))
print(res3)
#5.根据1得到的列表,过滤掉名字以a开头的人的信息
res4 =list(filter(lambda i:i[title[0]][0]!='a',lt1))
print(res4)
#6.使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 5 8...)
def fbnq(x):
if x == 1:
return 0
if x == 2:
return 1
return fbnq(x-1)+fbnq(x-2)
print(fbnq(7))
#7.一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值