• 作业 3/25


    1、文件内容如下,标题为:姓名,性别,年纪,薪资
    egon male 18 3000
    alex male 38 30000
    wupeiqi female 28 20000
    yuanhao female 28 10000

    要求:
    从文件中取出每一条记录放入列表中,
    列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}的形式

    with open('tank.txt','r',encoding='utf-8') as f:
        value1 = [i.split() for i in f]
        key = ['name','sex','age','salary']
        dic = [{key[i] : value[i] for i in range(0,len(key))}for value in value1 ]
        print(dic)
    

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

    res = sum(int(i_dic['salary']) for i_dic in dic)
    print(res)
    

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

    l = [i_dic['name'] if i_dic['sex'] == 'male' else '' for i_dic in dic]
    print(l)
    

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

    l1 = []
    for person in dic:
        dic2 = {}
        for key in person.keys():
            if key == 'name':
                dic2[key] = person[key].title()
            else:
                dic2[key] = person[key]
        l1.append(dic2)
    print(l1)
    

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

    l = ['' if person['name'].startswith('a') else person for person in dic]
    print(l)
    

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

    def fb(x,y):
        print(y,end=' ')
        x,y = y,x+y
        fb(x,y)
    print(0,end=' ')
    fb(0,1)
    

    7 一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值

    def list1(l):
        for i in l:
            if type(i) == list:
                list1(i)
            else:
                print(i)
    l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]]
    list1(l)
    
  • 相关阅读:
    Boolean()类型转换
    ECMAscript 变量作用域
    jQuery 添加样式属性的优先级别
    css类选择器类名覆盖优先级
    巡风扫描器安装-windows部署
    atom无法安装插件的解决方法之一
    网络爬虫url跳转代码
    查看天气的代码
    三级地名菜单
    购物清单代码
  • 原文地址:https://www.cnblogs.com/pythonwl/p/12567596.html
Copyright © 2020-2023  润新知