Python函数式编程自带函数

简介: Python函数式编程自带函数

​### 一.map函数

需求1:num1=[1,2,3,4],我的需求是把num1中的每个元素平方后组成新列表。

ret = []
num1 = [1,2,3,4]
for i in num1:
    ret.append(i**2)

print(ret)

# 输出结果:
>>>[1, 4, 9, 16]

需求2:如果有1万个列表呢,怎么办?

思路:如果用for循环,当然功能上是没问题的,但是需要写很多重复代码,重复代码?? 顿时想到函数的特性就是避免重复代码,哈哈哈,天才也....

num1 = [1,2,3,4]
def foo(array):
    ret = []
    for i in array:
        ret.append(i**2)
    return ret
print(foo(num1))

"""
每个列表调用1次函数即可,一万个列表调用1万次foo函数就行了,不用写一万个for循环,问题解决。
"""

# 输出结果:
>>>[1, 4, 9, 16]

需求3:如果1万个列表,同时需要每个元素自加1,自减1,自乘1,自平方...???

思路:看到题目就在想,你是猴子派来玩我的吗??? 如果安装2中的方法,我去,需要一个功能一个函数,这真的可以吗? 当然不行,这样太out了...

def add_one(x):          # 定义自加一处理逻辑
    return x+1
def reduce_one(x):      # 定义自减一处理逻辑
    return x-1
def plus_one(x):        # 定义自平方处理逻辑
    return x**2


def map_test(func,array):
    ret = []
    for i in array:
        res = func(i)   # 相当于 res = add_one(i)
        ret.append(res)
    return ret

print(map_test(add_one,[1,2,3,4]))

# 运行结果
>>>[2, 3, 4, 5]

突发奇想:3中的代码在定义处理逻辑的时候,不就是lambda的处理方式吗,可不可以使用lambda代替呢??答案是肯定的。

def map_test(func, array):
    ret = []
    for i in array:
        res = func(i)
        ret.append(res)
    return ret

print(map_test(lambda x:x+1,[1,2,3,4]))

# 输出结果
>>> [2, 3, 4, 5]

哈哈,完美了...

此时我正沉浸在胜利的喜悦中,一个声音让我一下从天堂坠入地狱...

A:这个代码好臃肿啊,一行代码能完成的事情,为什么要写成这样呢???

我(心想):一行???吹呢吧,你要是能写,我拜你为师....

A:我告诉你吧,你的处理思维是没错的,但是Python自带的map函数完全可以替代你的上述代码,简单的很呦!!

print(map(lambda x:x+1,[1,2,3,4]))
# <map object at 0x0000000000597390>  map处理后得到的结果就是一个迭代器.
print(list(map(lambda x:x+1,[1,2,3,4])))

# 运行结果
>>> [2, 3, 4, 5]
# list函数可以把可迭代的对象变成列表

"""
map函数总结:
lambda x:x+1 (第一个参数)处理逻辑,不一定必须使用lambda
[1,2,3,4] (第二个参数)要处理的可迭代对象
"""

# 把字符串中的每个元素变成大写
msg = 'abcd'
print(list(map(lambda x:x.upper(),msg)))

# 运行结果
>>> ['A', 'B', 'C', 'D']

什么也不说了,师傅,请受徒儿一拜.....,抬头望去,人了??哎,高人就是不一样啊.....

二 .filter函数

需求1:电影院中有5个人在看电影,筛选出他们的名字前面不含sb字符的人

movie_people = ['sb_a','sb_b','sb_c','d','e']
ret = []
for p in movie_people:
    if not p.startswith('sb'):
        ret.append(p)

print(ret)

# 打印结果
>>> ['d', 'e']:

需求2:电影院中有5个人在看电影,筛选出他们的名字前后不含sb字符的人

movie_people = ['sb_a','sb_b','sb_c','d','e']

def sb_show(n):
    return n.startswith('sb')
def show_sb(n):
    return n.endstwith('sb')

def filter_test(array,func):
    ret = []
    for p in array:
        if  not func(p):
            ret.append(p)

    return ret

print(filter_test(movie_people,sb_show))

# 运行结果
>>> ['d', 'e']

终极版本:使用lambda代替上述代码中的show_sb和sb_show函数。

def filter_test(array,func):
    ret = []
    for p in array:
        if  not func(p):
            ret.append(p)

    return ret

print(filter_test(movie_people,lambda x:x.startswith('sb')))

# 运行结果
>>> ['d', 'e']

使用自带函数filter完成

movie_people = ['sb_a','sb_b','sb_c','d','e']
print(list(filter(lambda x:not x.startswith('sb'),movie_people)))

"""
filter说明:
第一个参数:处理逻辑,结果必须是一个布尔值
第二个参数:要处理的可迭代的内容
"""

三. reduce函数

reduce函数在Python2中可以直接使用,在Python3中需要引用(from functools import reduce)。

处理一个序列,然后把序列中的每个元素进行合并(相加、相乘等)操作。

实例

num_1 = [1,2,3,4]
from functools import reduce
print(reduce(lambda x,y:x+y,num_1,10))

# 运行结果
>>> 20

"""
第一个参数:处理逻辑
第二个参数:可迭代对象
第三个参数:初始值,如果有初始值,会把初始值也进行合并
"""

四.函数对照表

请在此添加图片描述

需求:有一个列表,筛选出age小于1000的人

思路:此需求中是要过滤age小于1000的人,三个函数中可以选择filter()

people = [
    {
   
   'name':'alex','age':1000},
    {
   
   'name':'wupeiq','age':10000},
    {
   
   'name':'linhaifeng','age':18}
]

print(list(filter(lambda x:x['age'] < 1000,people)))

# 运行结果
>>> [{
   
   'age': 18, 'name': 'linhaifeng'}]
相关文章
|
22天前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
125 67
|
16天前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
42 18
|
8天前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
39 8
|
17天前
|
Python
Python中的函数
Python中的函数
31 8
|
24天前
|
监控 测试技术 数据库
Python中的装饰器:解锁函数增强的魔法####
本文深入探讨了Python语言中一个既强大又灵活的特性——装饰器(Decorator),它以一种优雅的方式实现了函数功能的扩展与增强。不同于传统的代码复用机制,装饰器通过高阶函数的形式,为开发者提供了在不修改原函数源代码的前提下,动态添加新功能的能力。我们将从装饰器的基本概念入手,逐步解析其工作原理,并通过一系列实例展示如何利用装饰器进行日志记录、性能测试、事务处理等常见任务,最终揭示装饰器在提升代码可读性、维护性和功能性方面的独特价值。 ####
|
1月前
|
Python
Python中的`range`函数与负增长
在Python中,`range`函数用于生成整数序列,支持正向和负向增长。本文详细介绍了如何使用`range`生成负增长的整数序列,并提供了多个实际应用示例,如反向遍历列表、生成倒计时和计算递减等差数列的和。通过这些示例,读者可以更好地掌握`range`函数的使用方法。
47 5
|
1月前
|
测试技术 数据安全/隐私保护 Python
探索Python中的装饰器:简化和增强你的函数
【10月更文挑战第24天】在Python编程的海洋中,装饰器是那把可以令你的代码更简洁、更强大的魔法棒。它们不仅能够扩展函数的功能,还能保持代码的整洁性。本文将带你深入了解装饰器的概念、实现方式以及如何通过它们来提升你的代码质量。让我们一起揭开装饰器的神秘面纱,学习如何用它们来打造更加优雅和高效的代码。
|
1月前
|
弹性计算 安全 数据处理
Python高手秘籍:列表推导式与Lambda函数的高效应用
列表推导式和Lambda函数是Python中强大的工具。列表推导式允许在一行代码中生成新列表,而Lambda函数则是用于简单操作的匿名函数。通过示例展示了如何使用这些工具进行数据处理和功能实现,包括生成偶数平方、展平二维列表、按长度排序单词等。这些工具在Python编程中具有高度的灵活性和实用性。
35 2
|
2月前
|
Python
python的时间操作time-函数介绍
【10月更文挑战第19天】 python模块time的函数使用介绍和使用。
38 4
|
1月前
|
中间件 Docker Python
【Azure Function】FTP上传了Python Function文件后,无法在门户页面加载函数的问题
通过FTP上传Python Function至Azure云后,出现函数列表无法加载的问题。经排查,发现是由于`requirements.txt`中的依赖包未被正确安装。解决方法为:在本地安装依赖包到`.python_packages/lib/site-packages`目录,再将该目录内容上传至云上的`wwwroot`目录,并重启应用。最终成功加载函数列表。
下一篇
DataWorks