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)