9.25作业

一. 文件内容如下,标题为:姓名,性别,年纪,薪资

egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000

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

lt1 = ['name','sex','age','salary']
dic2 = []
with open('jsb.txt','r',encoding='utf-8')as fr:
    for lt2 in fr:
        lt2 = lt2.strip().split()
        # print(lt2)
        dic = {k : v for k,v in zip(lt1,lt2)}
        dic2.append(dic)
print(dic2)
  1. 根据1得到的列表,取出薪资最高的人的信息
res = max(dic2,key = lambda dic:int(dic['salary']))
print(res)
  1. 根据1得到的列表,取出最年轻的人的信息
res = min(dic2,key = lambda dic:int(dic['age']))
print(res)
  1. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
def upper_dic(dic2):
    dic2['name'] = dic2['name'].title()
    return dic2
res = map(upper_dic,dic2)
dic2 = list(res)
print(dic2)
  1. 根据1得到的列表,过滤掉名字以a开头的人的信息
res = filter(lambda dic:not dic['name'].startswith('a'),dic2)
print(list(res))

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

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

转载于:https://www.cnblogs.com/793564949liu/p/11588035.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值