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(r'db.txt','r',encoding='utf-8')as f:
l = []
new_l = [i.strip().split(' ') for i in f]
for x in new_l:
value = [value for value in x]
keys = ['name', 'sex', 'age','salary']
dic = {k:v for k,v in zip(keys,value)}
l.append(dic)
print(l)
2 根据1得到的列表,取出所有人的薪资之和
user_sum = sum(int(msg.get('salary')) for msg in l)
print(user_sum)
3 根据1得到的列表,取出所有的男人的名字
name_of_man = [name.get('name') for name in l if name.get('sex') == 'male']
print(name_of_man)
4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
user_name = [name.get('name').title() for name in l]
print(user_name)
5 根据1得到的列表,过滤掉名字以a开头的人的信息
change_name = [name for name in l if not name.get('name').startswith('a')]
print(change_name)
6 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
递归法
def fib2(n):
if n <= 1:
return n
return fib2(n-2)+fib2(n-1)
for i in range(0,20):
print(fib2(i),end=' ')
递推法
# 从时间复杂度来看,能用递推算法最好不要用递归
def fib1(n,x=0, y=1):
for i in range(n):
print(x,end=' ')
x, y = y, x + y
fib1(9)
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, ]]]]]]]]]]
def f1(l):
for x in l:
if type(x) is list:
f1(x)
else:
print(x,end=' ')
f1(l)