emmm......就当练习了系列15

Posted lucky-cat233

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了emmm......就当练习了系列15相关的知识,希望对你有一定的参考价值。

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

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

with open(‘db.txt‘, ‘rt‘, encoding=‘utf-8‘) as f:
items = (line.split() for line in f)
info = [{‘name‘: name, ‘sex‘: sex, ‘age‘: age, ‘salary‘: salary}
for name, sex, age, salary in items]

print(info)



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

print(sum(dic[‘salary‘] for dic in info))

 

 


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

print(dic[‘name‘] for dic in info if dic[‘sex‘] == ‘male‘)

 

 


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

info_new = map(lambda item: {‘name‘: item[‘name‘].capitalize(),
‘sex‘: item[‘sex‘],
‘age‘: item[‘age‘],
‘salary‘: item[‘salary‘]}, info)

print(list(info_new)

 

 


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

new_list = [dic for dic in info if not dic[‘name‘].startswith(‘a‘)]
print(new_list)

 

 


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

def fibo(a,b,stop):
if a > stop:
return
print(a, end=‘ ‘)
fibo(b, a+b, stop)

fibo(0,1,10)

 

 


7 一个嵌套很多层的列表,如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 func(l):
for x in l:
if type(x) is list:
# 如果是列表,应该再循环、再判断,即重新运行本身的代码
func(x)
else:
print(x)

func(l)

 

以上是关于emmm......就当练习了系列15的主要内容,如果未能解决你的问题,请参考以下文章

emmm......就当练习了系列09

emmm......就当练习了系列18

emmm......就当练习了系列17

emmm......就当练习了系列04

Python3练习题系列(03)

实验4-1-1 最大公约数和最小公倍数 (15分)emmm辗转相除法