文件内容如下,标题为:姓名,性别,年纪,薪资
egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000
要求:
1.从文件中取出每一条记录放入列表中,列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式
list1 = []
with open(r'db.txt', mode='rt', encoding='UTF-8') as f:
for line in f:
l = {}
name, sex, age, salary = line.strip().split(' ')
l['name'] = name
l['sex'] = sex
l['age'] = int(age)
l['salary'] = int(salary)
list1.append(l)
print(list1)
2.根据1得到的列表,取出所有人的薪资之和
salary_sum = [dic['salary'] for dic in list1]
print(sum(salary_sum))
3.根据1得到的列表,取出所有的男人的名字
male_name = [line['name'] for line in list1 if line['sex'] == 'male']
print(male_name)
4.根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
for line in list1:
line['name'] = line.get('name').capitalize()
print(line)
5.根据1得到的列表,过滤掉名字以a开头的人的信息
print([line for line in list1 if not line.get('name').startswith('a')])
6.使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 5 8...)
def pbnq(x,y):
print(x + y)
if x > 100:
return
x,y = y ,x+y
pbnq(x,y)
pbnq(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 f1(list1):
for x in list1:
if type(x) is list:
# 如果是列表,应该再循环、再判断,即 重新运行本身的代码
f1(x)
else:
print(x)