Python学习6---高级函数式编程

embedded/2024/9/23 9:25:54/

1. 函数式编程简介
函数式编程(Functional Programming, FP)是一种编程范式,主要基于数学中的函数概念。与面向对象编程(OOP)不同,FP 更关注函数的应用而不是对象的状态。FP 的主要特点包括:
**纯函数:**函数的输出仅依赖于其输入,没有副作用。
不可变数据:数据一旦创建就不能被修改。
**高阶函数:**可以接受函数作为参数或返回函数的函数。

2. 函数式编程的核心概念
2.1 纯函数
纯函数的输出只依赖于输入参数,不依赖于外部状态,也不会改变外部状态。这样的函数具有可预测性和可测试性。
示例:

python">def pure_add(x, y):return x + y# 调用纯函数
result = pure_add(2, 3)
print(result)  # 输出:5

2.2 不可变数据
不可变数据一旦创建就不能修改。使用不可变数据可以避免因为数据修改导致的错误。
示例:

python">from collections import namedtuple# namedtuple:创建一个和tuple类似的对象,而且对象拥有可访问的属性。
# 定义一个namedtuple类型Point,并包含x和y属性。
Point = namedtuple('Point', ['x', 'y'])
p1 = Point(1, 2)# 不可变数据不能直接修改
# p1.x = 3  # 这会导致错误# 修改对象属性,注意要使用"_replace"方法
Point= Point._replace(x=3)p2 = Point(p1.x, 3)
print(p2)  # 输出:Point(x=1, y=3)

2.3 高阶函数
高阶函数是可以接受其他函数作为参数或返回值的函数。常见的高阶函数包括map、filter和reduce。
示例:

python">def apply_twice(func, x):return func(func(x))def increment(x):return x + 1# 调用高阶函数
result = apply_twice(increment, 5)
print(result)  # 输出:7

3. 函数式编程工具
3.1 lambda函数
lambda函数是匿名函数,可以在需要一个简单函数而不想定义完整函数时使用。
示例:

python"># 使用lambda函数
add = lambda x, y: x + y
print(add(2, 3))  # 输出:5

3.2 map, filter 和 reduce
这些函数用于函数式数据处理:
map:将一个函数应用到序列的每个元素上,返回一个迭代器。
filter:过滤序列中的元素,返回一个迭代器。
reduce:对序列中的元素进行累积操作,返回一个单一结果。

python">from functools import reduce# map函数
squares = map(lambda x: x * x, [1, 2, 3, 4])
print(list(squares))  # 输出:[1, 4, 9, 16]# filter函数
evens = filter(lambda x: x % 2 == 0, [1, 2, 3, 4])
print(list(evens))  # 输出:[2, 4]# reduce函数
product = reduce(lambda x, y: x * y, [1, 2, 3, 4])
print(product)  # 输出:24

3.3 functools模块
functools模块提供了许多有用的工具来辅助函数式编程,比如partial和lru_cache。
示例:

python">from functools import partial, lru_cache# partial函数:把一个函数的某些参数给固定住,返回一个新的函数。
def power(base, exponent):return base ** exponent	# 此处,固定的是power函数的exponent参数。
# partial(power, 2):固定的是power函数的第一个参数
square = partial(power, exponent=2)
print(square(5))  # 输出:25# lru_cache装饰器
@lru_cache(maxsize=None)
def fibonacci(n):if n < 2:return nreturn fibonacci(n-1) + fibonacci(n-2)print(fibonacci(10))  # 输出:55

4. 函数式编程的实际应用
4.1 列表处理
函数式编程在列表处理和数据转换方面非常高效。
示例:

python">data = [1, 2, 3, 4, 5]# 使用map和filter处理列表
squared_evens = map(lambda x: x * x, filter(lambda x: x % 2 == 0, data))
print(list(squared_evens))  # 输出:[4, 16]

4.2 数据转换
利用高阶函数和lambda函数,可以轻松地进行数据转换。
示例:

python">data = [{'name': 'Alice', 'age': 30}, {'name': 'Bob', 'age': 25}]# 将数据转换为另一种形式
names = map(lambda x: x['name'], data)
print(list(names))  # 输出:['Alice', 'Bob']

4.3 并行处理
通过使用函数式编程技术,可以简化并行处理任务。
示例:

python">import concurrent.futuresdef square(x):return x * xwith concurrent.futures.ThreadPoolExecutor() as executor:results = list(executor.map(square, [1, 2, 3, 4]))
print(results)  # 输出:[1, 4, 9, 16]

http://www.ppmy.cn/embedded/95736.html

相关文章

PostgreSQL的部分索引

每个数据库的部分索引还不一样 我以前用过MySQL的部分索引。不过说实话使用场景不多。于是上次本来打算在书中也写这个。结果徐老师说PG的不一样。后来我尝试了。果然不一样。 xxg# explain select * from xxg; QUERY PLAN Seq Scan on xxg (cost0.00…45691.00 rows100000 …

CentOS7安装流程步骤详细教程

1. 简介 1.1. 概述 CentOS 7是一款基于Red Hat Enterprise Linux(RHEL)的开源Linux发行版,它提供了一个稳定、安全、高效的操作系统,适用于企业级应用、服务器、云计算等领域。CentOS 7以其高度的稳定性和安全性而闻名,它广泛应用于各种行业和领域,包括政府、金融、医疗、…

weblogic漏洞——CVE-2020-14882

一、基本信息 靶机&#xff1a;IP&#xff1a;192.168.100.40 二、攻击过程 进入 vulhub 靶场相关目录&#xff0c;并启动环境 cd master/weblogic/CVE-2020-14882 docker-compose up -d 绕过登录验证 http://192.168.100.40:7001/console/css/%252e%252e%252fconsole.por…

UIButton的UIEdgeInsetsMake属性(setTitleEdgeInsets,setImageEdgeInsets)

一.UIEdgeInsetsMake的四个属性 UIEdgeInsetsMake 有四个属性,依次是 Top,left,bottom,right [Btn setTitleEdgeInsets:UIEdgeInsetsMake( top, left, bottom, right)]; 四个属性的默认值为0,拿其中一个left属性来聊, 你可以理解为文字距离Btn左边界的“位移”是0, 如果…

Harbor私有仓库

一.什么是Harbor私有仓库 Harbor 是一个开源的企业级 Docker 镜像仓库&#xff0c;提供了对 Docker 镜像的管理和分发功能。它作为私有仓库&#xff0c;允许组织在内部安全地存储和管理 Docker 镜像。Harbor 提供了图形用户界面、访问控制、审计日志、镜像扫描、复制和备份等功…

程序员如何平衡日常编码工作与提升式学习?

程序员如何平衡日常编码工作与提升式学习&#xff1f; 在快速迭代的编程世界中&#xff0c;程序员们不仅需要高效完成日常编码任务&#xff0c;还需不断学习新技术、深化专业知识&#xff0c;以应对日益复杂的项目挑战。然而&#xff0c;如何在繁忙琐碎的编码工作与个人成长之…

2024-08-15 商业分析-20240815事项-误区分析

摘要: 技术作为最后实现的最后一个环节&#xff0c;总是无法脱离商业场景独立存在&#xff0c;即使是作为基础设施&#xff0c;也是作为整个分层体系的一个部分而支撑起更为上层的业务。作为单纯的实现手段来看&#xff0c;也是与更为上层的逻辑存在一些不同。作为现实世界的一…

C++(27): 线程池

目录 1. 概述 2. 例程 &#xff08;1&#xff09;ThreadPool.h &#xff08;2&#xff09;ThreadPool.cpp &#xff08;3&#xff09;Start.cpp &#xff08;4&#xff09;编译 1. 概述 线程池技术绝不是C独有的&#xff0c;Java和Python都有比较晚完善的线程池构造接口…