python 高阶函数

coding:utf-8

当前系统日期:2022/8/8

from functools import reduce

高阶函数,函数套用函数

递归

lambda 简化代码,减少占用的内存,只有一句代码,有一个返回值

lambda 形参:代码

def fun1(a, b):
    return a + b


print(fun1(1, 2))
fun2 = lambda a, b: a + b
print(fun2(1, 2))

list1 = [[1, '1'], [3, '3'], [2, '2']]
for _ in list1:
    print(_[0])
list1.sort(key=lambda j: j[0])  # 把列表里面的数据循环出来,并排序
print(list1)

map 映射

map(func,list)

list2 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
print(list(map(lambda i: str(i), list2)))  # 迭代器

reduce(func,list) 累积

print(reduce(lambda a, b: a + b, list2))

filter(func,list) 过滤不符合表达式的数据

print(list(filter(lambda i: i % 2 == 0, list2)))

递归,函数内部自己调用自己,必须要有出口

def func(_):
    if _ == 1:
        return 1
    return _ + func(_ - 1)


print(func(4))
list3 = [1, 2, [3, [4, 5], [6, 7, 8]], [9, 0]]

list0 = []
def fun3(data):
    if type(data) == type([]):
        for _ in data:
            fun3(_)
    else:
        list0.append(data)
    return list0


print(fun3(list3))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值