课后作业 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}`的形式
user_info = []
user_iteams = ['name','sex','age','salary']
with open('work.txt','r',encoding='utf8') as fr:
for i in fr:
uesr_values = i.strip().split()
res_dic = {k: v for k, v in zip(user_iteams, uesr_values)}
user_info.append(res_dic)
print(user_info)
# 1. 根据1得到的列表,取出薪资最高的人的信息
print(max(user_info, key= lambda dic :dic['salary']))
# 2. 根据1得到的列表,取出最年轻的人的信息
print(min(user_info, key= lambda dic :dic['age']))
# 3. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
res_Name = map(lambda iteam : iteam['name'].capitalize() ,user_info)
print(list(res_Name))
# 4. 根据1得到的列表,过滤掉名字以a开头的人的信息
filter_a = filter(lambda iteam :not iteam['name'].startswith('a') ,user_info)
print(list(filter_a))
# 5. 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
fob = []
count = 0
x,y = 0,1
def f1(num):
global count,x,y
while count < num:
if count == 0 or num == 0:
fob.append(x)
count += 1
f1(num)
elif count == 1 or num == 1:
fob.append(y)
count += 1
f1(num)
else:
z = x + y
x = y
y = z
fob.append(z)
count +=1
f1(num)
f1(6)
print(fob)
# 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 f6(l):
for val in l:
if type(val) == list:
f6(val)
else:
print(val)
f6(l)
##方法二
def for1(iterable):
iterator = iterable.__iter__()
while True:
try:
res = iterator.__next__()
if type(res) == list:
for1(res)
else:
print(res)
except StopIteration:
break
for1(l)