zoukankan      html  css  js  c++  java
  • 生成器表达式作业

    # 1、文件内容如下,标题为:姓名,性别,年纪,薪资
    # 要求:
    # 从文件中取出每一条记录放入列表中,
    # 列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式

    dic = ['name','sex','age','salary']
    with open('a.txt','rt',encoding='utf-8')as f:
        l = [dict(zip(dic, res.strip().split(' '))) for res in f]
        print(l)

    # 2 根据1得到的列表,取出所有人的薪资之和

    res = sum(int(i.get('salary')) for i in l)
    print(res)

    # 3 根据1得到的列表,取出所有的男人的名字

    res = [i.get('name') for i in l if i.get('sex') == 'male']
    print(res)

    # 4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式

    # 方式一:
    # res = map(lambda x:x.get('name')[0].upper() + x.get('name')[1:], user_list)
    # print(list(res))
     
    # 方式二:
    # str.capitalize()字符串的内置方式,可以将字符串中的首字母改为大写
    # x.get('name').capitalize()  --> name  {'name': name, 'sex': x.get('sex'), 'age': x.get('age')}
    # res = map(lambda x:
    #           {'name': x.get('name').capitalize(), 'sex': x.get('sex'), 'age': x.get('age'), 'salary': x.get('salary')},
    #           user_list
    #           )
    # print(list(res))

    # 5 根据1得到的列表,过滤掉名字以a开头的人的信息

    res = [i for i in l if not i.get('name').startswith('a')]
    print(res)

    # 6 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 5 8...)

    def fab(n,a=0,b=1):
        if n == 0:
            return
        print(a)
        a,b= b, a + b
        n = n-1
        fab(n,a,b)
    fab(5)

    # 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 func(l):
        for i in l:
            if type(i) is list:
                func(i)
            else:
                print(i)
    func(l)
  • 相关阅读:
    Java数据结构和算法(2)之稀疏数组
    Java数据结构和算法(1)之队列
    Redis之Redis的数据类型
    Redis之Redis入门介绍
    Redis之NoSql入门和概述(二)
    rpc(二、springboot2.3.2+dubbo2.7.7)
    rpc(一、基础)
    zookeeper(二、curatorAPI使用)
    zookeeper(一、集群部署)
    项目部署(三、docker+Jenkins+springboot部署)
  • 原文地址:https://www.cnblogs.com/bk134/p/12568726.html
Copyright © 2011-2022 走看看