days14

  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}的形式

lt = []
s = ['name','sex','age','salary']
with open('user_info.txt','r',encoding='utf8')as fr:
    for line in fr:
        date = line.strip().split(' ')
        dic = {k: v for k, v  in zip(s, date)}
        lt.append(dic)

    print(lt)
  1. 根据1得到的列表,取出薪资最高的人的信息
def func(dic):
    return dic['salary']
res=max(lt,key=func)
print(res)
  1. 根据1得到的列表,取出最年轻的人的信息
def age(dic):
    return dic['age']
res1=min(lt,key=age)
print(res1)
  1. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
def name1(dic):
    return  dic['name'].title()
res_2 = map(name1,lt)
res2=list(res_2)
print(res2) #四个大写名字

for i in range(len(res2)):
    lt[i]['name'] = res2[i]
print(lt)
  1. 根据1得到的列表,过滤掉名字以a开头的人的信息
def name2(dic):
    return not dic['name'].startswith('a')
res3 = filter(name2,lt)
print(list(res3))
  1. 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
def fib(n):
    if n == 1 or n == 2:
        return 1
    else:
        return fib(n - 1) + fib(n - 2)
  1. 一个嵌套很多层的列表,如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]]]]]]]

# 思路
for i in l:

    if type(i) == list:
        for j in i:
            print(j)
    else:
        print(i)

# 递归思想
def get(lis):
    for i in lis:
        if type(i) == list:
            get(i)
        else:
            print(i)


get(l)

转载于:https://www.cnblogs.com/jzm1201/p/11587584.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值