作业 3/25

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('tank.txt','r',encoding='utf-8') as f:
    value1 = [i.split() for i in f]
    key = ['name','sex','age','salary']
    dic = [{key[i] : value[i] for i in range(0,len(key))}for value in value1 ]
    print(dic)

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

res = sum(int(i_dic['salary']) for i_dic in dic)
print(res)

3 根据1得到的列表,取出所有的男人的名字

l = [i_dic['name'] if i_dic['sex'] == 'male' else '' for i_dic in dic]
print(l)

4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式

l1 = []
for person in dic:
    dic2 = {}
    for key in person.keys():
        if key == 'name':
            dic2[key] = person[key].title()
        else:
            dic2[key] = person[key]
    l1.append(dic2)
print(l1)

5 根据1得到的列表,过滤掉名字以a开头的人的信息

l = ['' if person['name'].startswith('a') else person for person in dic]
print(l)

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

def fb(x,y):
    print(y,end=' ')
    x,y = y,x+y
    fb(x,y)
print(0,end=' ')
fb(0,1)

7 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值

def list1(l):
    for i in l:
        if type(i) == list:
            list1(i)
        else:
            print(i)
l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]]
list1(l)
原文地址:https://www.cnblogs.com/pythonwl/p/12567596.html