day23 内置函数,匿名函数,递归
Posted 何必从头
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了day23 内置函数,匿名函数,递归相关的知识,希望对你有一定的参考价值。
Python之路,Day11 = Python基础11
内置函数
divmod(x, y) # (商, 模)
enumerate(可迭代对象) # (序号,值)
eval(字符串) # 把字符串当成命令执行
set({1,2,3}) # 可变集合(增删改)
frozenset({1,2,3}) # 不可变集合
globals() # 查看全局变量
locals() # 查看局部变量
isinstance(3, int) # 查看3是不是int类型
pow(3,3) # 3**3
pow(3,3,2) # 3**3 % 2
reversed() # 翻转
round(3.3456, 3) # 保留3位小数后四舍五入
x = slice(2,5,2) # 获得一个切片对象
l[x]
上面两句等同于: l[2:5:2], 但上面定义的 x 可以提供给好多个列表使用
zip():拉链函数
s = ‘hello‘
l = [1,2,3,4,5,6]
zip(s,l)
一 一对应,多的就不要了
map:映射,每个元素执行lambda表达式结果
l=[1,2,3,4]
m = map(lambda x:x**2, l)
生成一个迭代器,循环后结果
print(list(m))
>>[1,4,9,16]
reduce:合并
from functools import reduce
reduce(合并规则(func),可迭代对象range(100),初始值)
filter
filter(lambda, 列表) # 打印返回结果为True的值
sorted:排序,没有改变原来的顺序
sorted(list)
sorted(list, reverse=True)
匿名函数
func2 = lambda x:x**2 # 默认return
print( func2(2) )
等同于:
def func(x):
return x**2
print( func1(2) )
递归
1.之间或间接调用自己
2.有停止的条件
3.规模应该每次变小
=========================================================
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}的形式
2 根据1得到的列表,取出薪资最高的人的信息
3 根据1到的列表,取出最年轻的人的信息
4 根据1得到的列表,将每个人的信息中的名字映射成首字母大写的形式
5 根据1得到的列表,过滤掉名字以a开头的人的信息
1 info_list = [{‘name‘:i.split()[0],‘sex‘:i.split()[1], ‘age‘:i.split()[2], ‘salary‘:i.split()[3]} for i in open(‘info‘,encoding=‘utf-8‘)] 2 3 4 print(max(info_list,key=lambda x:x[‘salary‘])) # 最大值 5 print(min(info_list,key=lambda x:x[‘age‘])) # 最小值 6 7 def func1(x): 8 x[‘name‘] = x[‘name‘].capitalize() 9 return x 10 11 # print(list(map(lambda x:x[‘name‘].capitalize(), info_list))) 12 print(list(map(func1, info_list))) 13 14 # 首字母大写,目测有点问题,等会儿解决下 15 16 17 print(list(filter(lambda x:not x[‘name‘].startswith(‘a‘), info_list)))
# 6 使用递归打印j(前两个数的和得到第三个数)
# 0 1 1 2 3 5 8...
def nbqe(a=0, b=1): if a < 50000: print(a, end=‘ ‘) c = a + b nbqe(b, c) nbqe() # ===================================== l = [0, ] def fbnq(a=0, b=1): l[0] = a return b,a+b a = 0 b = 1 total = 100000 for i in range(total): a, b = fbnq(a, b) print(‘第%s个值为:%s‘%(total, l[-1]))===
以上是关于day23 内置函数,匿名函数,递归的主要内容,如果未能解决你的问题,请参考以下文章