- 文件内容如下,标题为:姓名,性别,年纪,薪资
egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000
要求:
从文件中取出每一条记录放入列表中,列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}
的形式
lt = []
s = ['name','sex','age','salary']
with open('user_info.txt','r',encoding='utf8')as fr:
for line in fr:
date = line.strip().split(' ')
dic = {k: v for k, v in zip(s, date)}
lt.append(dic)
print(lt)
- 根据1得到的列表,取出薪资最高的人的信息
def func(dic):
return dic['salary']
res=max(lt,key=func)
print(res)
- 根据1得到的列表,取出最年轻的人的信息
def age(dic):
return dic['age']
res1=min(lt,key=age)
print(res1)
- 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
def name1(dic):
return dic['name'].title()
res_2 = map(name1,lt)
res2=list(res_2)
print(res2) #四个大写名字
for i in range(len(res2)):
lt[i]['name'] = res2[i]
print(lt)
- 根据1得到的列表,过滤掉名字以a开头的人的信息
def name2(dic):
return not dic['name'].startswith('a')
res3 = filter(name2,lt)
print(list(res3))
- 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
def fib(n):
if n == 1 or n == 2:
return 1
else:
return fib(n - 1) + fib(n - 2)
- 一个嵌套很多层的列表,如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]]]]]]]
# 思路
for i in l:
if type(i) == list:
for j in i:
print(j)
else:
print(i)
# 递归思想
def get(lis):
for i in lis:
if type(i) == list:
get(i)
else:
print(i)
get(l)