文件内容如下,标题为:姓名,性别,年纪,薪资
egon male 18 3000
alex male 38 30000
wupeiqi female 28 20000
yuanhao female 28 10000
要求:
从文件中取出每一条记录放入列表中,列表的每个元素都是{'name':'egon','sex':'male','age':18,'salary':3000}
的形式
-
根据1得到的列表,取出薪资最高的人的信息
salary_dict = { 'egon': 3000, 'alex': 30000, 'wupeiqi': 20000, 'yuanhao': 10000 } print(f"max(salary_dict): {max(salary_dict)}") def func(k): return salary_dict[k] print(f"max(salary_dict, key=func()): {max(salary_dict, key=func)}") # 'egon', v1 = func('egon') # 'alex', v2 = func('alex') # 'wupeiqi v3 = func('wupeiqik') # 'yuanhao', v4 = func('yuanhao') print( f"max(salary_dict, key=lambda name: salary_dict[name]): {max(salary_dict, key=lambda name: salary_dict[name])}")
-
根据1得到的列表,取出最年轻的人的信息
print(min(mylist, key=lambda x:x['age']))
-
根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
res = max(salary_dict, key=func) # 默认key的首字母 res = max(salary_dict, key=lambda name: salary_dict[name]) # 默认key的首字母 print(res)
-
根据1得到的列表,过滤掉名字以a开头的人的信息
res = filter(lambda x:x['name'][0]!='a',mylist) print(list(res))
-
使用递归打印斐波那契数列(前两个数的和得到第三个数,如: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)
-
一个嵌套很多层的列表,如l=[1,2,[3,[4,5,6,[7,8,[9,10,[11,12,13,[14,15]]]]]]],用递归取出所有的值