python 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('a.txt', 'r+t', encoding='utf-8') as f:
l = []
for line in f:
name, sex, age, salary = line.strip('\n').split(' ')
d = {'name': name, 'sex': sex, 'age': age, 'salary': salary}
l.append(d)
# 2 根据1得到的列表,取出所有人的薪资之和
res = sum(int(i['salary']) for i in l)
print(res)
# 3 根据1得到的列表,取出所有的男人的名字
man_list = []
lis = [man_list.append(i['name']) for i in l if i['sex'] == 'male']
print(man_list)
# 4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
new_l = [i['name'].capitalize() for i in l]
print(new_l) # ['Egon', 'Alex', 'Wupeiqi', 'Yuanhao']
# 5 根据1得到的列表,过滤掉名字以a开头的人的信息
new_lis = [i for i in l if not i['name'].startswith("a")]
print(new_lis)
# 6 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
def num_sum(a,b):
if a>10:
return
print(a, b)
a,b = b,a+b
num_sum(a,b)
num_sum(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 get_v(lis):
for i in lis:
if type(i) is list:
get_v(i)
return
print(i)
get_v(l)
# 选做作业:同昨天