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得到的列表,取出最年轻的人的信息
- 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
- 根据1得到的列表,过滤掉名字以a开头的人的信息
- 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
- 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值
1
with open('user_info.txt','w',encoding='utf-8') as fw:
fw.write('''egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000''')
lis=[]
li=['name','sex','age','salary']
with open('user_info.txt','r',encoding='utf-8') as fr:
for i in fr:
info=i.strip().split(' ')
rse=zip(li,info)
dic={k:v for k,v in rse}
lis.append(dic)
print(lis)
2
max1=max(lis,key=lambda di:di['salary'] )
print(max1)
3
min1=min(lis,key=lambda di:di['age'] )
print(min1)
4
map1=map(lambda ma:ma['name'].capitalize(),lis)
map_lis=list(map1)
count=0
for i in lis:
i['name']=map_lis[count]
count+=1
print(lis)
5
filter1=filter(lambda cs:not cs['name'].startswith('A'),lis)
print(list(filter1))
6
def n1(z,x=1,y=0):
print(x)
z-=1
if z==0:
return
x,y=x+y,x
n1(z,x,y)
n1(20)
7
l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]]
def n1(x):
y=x.__iter__()
for i in y:
try:
if len(i)>1:
n1(i)
except Exception:
print(i)
n1(l)