• emmm......就当练习了系列15


    文件内容如下,标题为:姓名,性别,年纪,薪资
    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}的形式

    with open('db.txt', 'rt', encoding='utf-8') as f:
    items = (line.split() for line in f)
    info = [{'name': name, 'sex': sex, 'age': age, 'salary': salary}
    for name, sex, age, salary in items]

    print(info)



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

    print(sum(dic['salary'] for dic in info))


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

    print(dic['name'] for dic in info if dic['sex'] == 'male')


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

    info_new = map(lambda item: {'name': item['name'].capitalize(),
    'sex': item['sex'],
    'age': item['age'],
    'salary': item['salary']}, info)

    print(list(info_new)


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

    new_list = [dic for dic in info if not dic['name'].startswith('a')]
    print(new_list)


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

    def fibo(a,b,stop):
    if a > stop:
    return
    print(a, end=' ')
    fibo(b, a+b, stop)

    fibo(0,1,10)


    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 x in l:
    if type(x) is list:
    # 如果是列表,应该再循环、再判断,即重新运行本身的代码
    func(x)
    else:
    print(x)

    func(l)
  • 相关阅读:
    KDJ回测
    利用网易获取所有股票数据
    利用东方财富网获取股票代码
    python发邮件
    用指针向数组插入元素
    冒泡排序
    Hadoop的安装与配置
    关于执行memcached报错问题
    tomcat Linux安装
    网易CentOS yum源
  • 原文地址:https://www.cnblogs.com/lucky-cat233/p/12568340.html
Copyright © 2020-2023  润新知