20.03.25作业
3月25号
# 1、文件内容如下,标题为:姓名,性别,年纪,薪资
# 要求:
# 从文件中取出每一条记录放入列表中,
# 列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式
a.txt
# egon male 18 3000
# alex male 38 30000
# wupeiqi female 28 20000
# yuanhao female 28 10000
with open('a.txt', 'rt', encoding='utf-8') as f:
info = [
{
'name': line.split()[0], 'sex': line.split()[1], 'age': line.split()[2], 'salary': line.split()[3]
} for line in f
]
print(info)
# 2 根据1得到的列表,取出所有人的薪资之和
data = (dic.get('salary') for dic in info)
print(sum(int(i) for i in data))
# 3 根据1得到的列表,取出所有的男人的名字
print([k.get('name') for k in info for v in k if k.get(v) == 'male'])
# 4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
for dic in info:
dic['name'] = dic.get('name').capitalize()
print(info)
# 5 根据1得到的列表,过滤掉名字以a开头的人的信息
print([dic for dic in info if not dic.get('name').startswith('a')])
# 6 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 5 8...)
def foo(n):
if n == 1:
return 0
if n == 2:
return 1
return foo(n-1) + foo(n - 2)
def foo(n):
x, y = 0, 1
for i in range(1, n+1):
if i == 1:
print(x)
elif i == 2:
print(y)
else:
x, y = y, x+y
print(y)
print(foo(6))
# 7 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值
def foo(obj):
for i in obj:
if type(i) is list:
foo(i)
else:
print(i)
l = [1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]]
foo(l)