• 小练习


    data = '''egon male 18 3000
    alex male 38 30000
    wupeiqi female 28 20000
    yuanhao female 28 10000'''
    with open('作业_14.txt','w',encoding='utf8') as fw:
        fw.write(data)
    
    #1.从文件中取出每一条记录放入列表中,列表的每个元素都是`{'name':'egon','sex':'male','age':18,'salary':3000}`的形式
    lt1 = []
    title = ['name','sex','age','salary']
    with open('作业_14.txt','r',encoding='utf8') as fr:
        for i in fr:
            lti = i.strip().split(' ')
            dici = {m:n for m,n in zip(title,lti)}
            lt1.append(dici)
    print(lt1)
    
    #2.根据1得到的列表,取出薪资最高的人的信息
    res1 = max(lt1,key=lambda i:i[title[-1]])
    print(res1)
    
    #3.根据1得到的列表,取出最年轻的人的信息
    res2 = min(lt1,key=lambda i:i[title[2]])
    print(res2)
    
    #4.根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
    res3 = list(map(lambda i:i[title[0]].title(),lt1))
    print(res3)
    
    #5.根据1得到的列表,过滤掉名字以a开头的人的信息
    res4 =list(filter(lambda i:i[title[0]][0]!='a',lt1))
    print(res4)
    
    #6.使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 5 8...)
    def fbnq(x):
        if x == 1:
            return 0
        if x == 2:
            return 1
        return fbnq(x-1)+fbnq(x-2)
    print(fbnq(7))
    
    #7.一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值
    
    
  • 相关阅读:
    python操作MySQL数据库
    fs 小计
    yii xss模型安全
    freeswitch 音 视频 支持的编码
    MYSQL手工注入某日本网站
    Linux 系统 pptpd+radius+mysql 安装攻略
    mysql主从复制之mysql-proxy实现读写分离
    nginx-1.2.7+tcp_proxy_module负载均衡配置
    nginx-1.2.7 + tcp_proxy_module手动编译安装
    关于弹框的那些事~
  • 原文地址:https://www.cnblogs.com/-406454833/p/11588621.html
Copyright © 2020-2023  润新知