课后作业 day14

课后作业 day 14

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

user_info = []
user_iteams = ['name','sex','age','salary']
with open('work.txt','r',encoding='utf8') as fr:
    for i in fr:
        uesr_values = i.strip().split()
        res_dic = {k: v for k, v in zip(user_iteams, uesr_values)}
        user_info.append(res_dic)

print(user_info)

# 1. 根据1得到的列表,取出薪资最高的人的信息
print(max(user_info, key= lambda dic :dic['salary']))

# 2. 根据1得到的列表,取出最年轻的人的信息
print(min(user_info, key= lambda dic :dic['age']))

# 3. 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
res_Name = map(lambda iteam : iteam['name'].capitalize() ,user_info)
print(list(res_Name))

# 4. 根据1得到的列表,过滤掉名字以a开头的人的信息
filter_a = filter(lambda iteam :not iteam['name'].startswith('a') ,user_info)
print(list(filter_a))

# 5. 使用递归打印斐波那契数列(前两个数的和得到第三个数,如:0 1 1 2 3 4 7...)
fob = []
count = 0
x,y = 0,1
def f1(num):
    global count,x,y
    while count < num:
        if count == 0 or num == 0:
            fob.append(x)
            count += 1
            f1(num)
        elif count == 1 or num == 1:
            fob.append(y)
            count += 1
            f1(num)
        else:
            z  = x + y
            x = y
            y = z
            fob.append(z)
            count +=1
            f1(num)
f1(6)
print(fob)

# 6. 一个嵌套很多层的列表,如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 f6(l):
    for val in l:
        if type(val) == list:
            f6(val)
        else:
            print(val)
f6(l)

##方法二
def for1(iterable):
    iterator = iterable.__iter__()
    while True:
        try:
            res = iterator.__next__()
            if type(res) == list:
                for1(res)
            else:
                print(res)
        except StopIteration:
            break
for1(l)

猜你喜欢

转载自www.cnblogs.com/samoo/p/11587080.html