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)
posted @ 2020-03-25 21:35  迎着阳光  阅读(229)  评论(0编辑  收藏  举报