百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

用Python进行函数式编程(python函数程序)

off999 2025-06-04 00:39 47 浏览 0 评论

什么是函数式编程?

函数式程序设计是一种编程范例,它把计算当作数学函数的评价,避免状态和可变数据。换句话说,函数编程(FunctionalProgramming,FP)促进没有副作用和不变变量的代码。它是一种声明式的编程风格。它的主要关注点是“解决什么”,而不是以“如何解决”为重点的命令式风格。

入门Python其实很容易,但是我们要去坚持学习,每一天坚持很困难,我相信很多人学了一个星期就放弃了,为什么呢?其实没有好的学习资料给你去学习,你们是很难坚持的,这是小编收集的Python入门学习资料关注,转发,私信小编“01”,即可免费领取!希望对你们有帮助


函数编程概念

1.纯函数

纯函数有两个性质:

(A)它们不会产生副作用。
(B)如果输入相同,它们总是产生相同的输出。这意味着函数不能依赖于任何可变状态。

副作用可由以下原因引起:

  • 更改函数作用域以外的数据。
  • 更改函数中参数的值。
  • 抛出异常或因错误而停止。
  • 打印到控制台或读取用户输入。
  • 从文件中读取或写入文件。

让我们看一个不纯函数的例子 .

num2 = 3
# Adds two numbers, but uses the global `num2` variable.
def add_impure(num1):
    return num1 + num2

print(add_impure(5))

现在让我们来看看添加两个数字的纯函数。

# Adds two numbers, using the arguments passed to the function.
def add_pure(num1, num2):
    return num1 + num2

print(add_pure(5, 3))

2.不变性

在函数式编程中,我们不能在变量初始化后改变它的值。这意味着,如果我们需要更改列表中的值,则需要创建一个具有更新值的新列表,而不是更改现有的列表。在FP中,变量的不可变性质有助于在整个程序执行过程中保持状态。在Python中,诸如int、Float、Complex、String、tuple、冻结集、字节等数据类型是不可变的。

#  id() function returns a unique id for the specified object.
num1 = 21
print(id(num1))

num1 = 12
print(id(num1))

-----------------------------------------------------------------------------------
OUTPUT:

1705703664
1705703520
tuple1 = (0, 1, 2, 3) 
tuple1[0] = 4
print(tuple1)

-----------------------------------------------------------------------------------
OUTPUT:

Traceback (most recent call last):
  File "D:/LeetCode/FP.py", line 2, in <module>
    tuple1[0] = 4
TypeError: 'tuple' object does not support item assignment

Process finished with exit code 1

3.递归

在fp中,我们避免if-etc语句或循环,因为它在每次执行时都会创建不同的输出。函数程序对所有的迭代任务使用递归代替循环。递归是一种函数,它一次又一次地调用自己,直到满足退出条件。

# returns factorial of a number
def factorial(num):

    if num == 1:
        return 1
    else:
        return num * factorial(num - 1)

  
print(factorial(5))

4.函数是一级的,可以是高阶的。

I nFP,功能被视为数据类型,并可与任何其他值一样使用。你可以分配f功能对于变量,将它们存储在数据结构中,将它们作为参数传递,或者在控制结构中使用它们。例如,我们可以用函数填充数组,将它们作为参数传递,或者将它们存储在变量中。

def cube(number):
    return number * number * number

my_cube = cube  # Assigning function as an object
print(my_cube(5))

numbers = [21, my_cube(5), 12]  # Storing function in list
print(numbers)

# Returning function from another function
def display_numbers():
    return my_cube(5)

print(display_numbers())

如果函数包含其他函数作为参数,或者将函数作为输出返回,则称为高阶函数。

映射、筛选和减少是Python中内置的一些高级函数。

高阶函数-映射

Map函数有两个参数。第一个参数是一个函数,第二个参数是可迭代的。然后,它将传递的函数应用于迭代中的每个项。

num = [1, 2, 3, 4, 5]
# returns square of each element in the list.
square = list(map(lambda number: number ** 2, num))
print(square)

-------------------------------------------------------------------------------------------
OUTPUT:

[1, 4, 9, 16, 25]

高阶函数滤波器

滤波函数允许您根据所提供的条件轻松地从更大的数据集中提取匹配的记录。 这需要两个论点。第一个参数是一个函数,第二个参数是可迭代的。Filter函数从函数返回true的可迭代元素中返回序列。

num = [1, 2, 3, 4, 5]
# returns even numbers from list.
even = list(filter(lambda number: number % 2 == 0, num))
print(even)

-------------------------------------------------------------------------------------------
OUTPUT:

[2, 4]

高阶函数-约简

约简函数接受一个函数和一个序列,并返回一个值,其计算方式如下:

  1. 最初,使用序列中的前两项调用函数,并返回结果。
  2. 然后,使用步骤1中获得的结果和序列中的下一个值再次调用该函数。此过程将被重复,直到序列中的每个项被迭代。
from functools import reduce

def add(num1, num2):
    return num1 + num2

print(reduce(add, [1, 2, 3, 4]))

-------------------------------------------------------------------------------------------
OUTPUT:

10

函数式编程的优点

  • 纯函数总是产生相同的输出,并且没有影响最终结果的外部值。因此,程序更容易测试和调试。
  • 我们可以编写高效的并行或并发程序,因为它们独立运行而不改变状态。
  • 它支持懒惰评价,这意味着我们评估价值并只在需要时存储它们。
  • 与OOP不同,FP支持更好的封装和纯功能。
  • 由于FP程序是由纯函数组成的,所以我们可以很容易地重用它们。

函数式程序设计的缺点

  • 当结合递归时,不可变值可能会降低性能。
  • 在某些情况下,编写纯函数可能会降低代码的可读性。
  • 函数式编程有状态。他们总是创建新的对象来执行操作,而不是对现有的对象进行更改。因此,FP应用程序占用了大量内存。
  • 编写纯函数很容易,但是将它们合并到一个完整的应用程序中是很困难的。

结语

这个博客提供了一个一瞥什么函数式编程做,并应提供一些背景如何他们是有益的。Python允许我们以函数式、声明式的方式进行编码。它甚至支持很多常见的函数特性(Likelambda)、map()、filter()和Reach(),这些特性可以帮助您编写简洁、高级和可并行的代码。

相关推荐

winxp安装盘(winxp系统安装)

xp系统安装步骤如下1、将下载的xp系统iso压缩包文件下载到C盘之外的分区,比如下载到D盘,右键使用WinRAR等工具解压到当前文件夹或指定文件夹,不能解压到C盘和桌面,否则无法安装;?2、解压之后...

现在的win11稳定了吗(win11稳定嘛)

windows10更稳定,由于win11刚刚推出没多久,稳定差不够好,兼容性也有待提升,无论是应用还是游戏都会遇到不明程度的问题,因此,在日常的使用过程中,我们还是应当以稳定性为优先,选择win10是...

xp安装包下载到手机(xp系统安装包)

手机是基于ARM架构的处理器,而WindowsXP是基于x86架构的操作系统,因此无法直接在手机上安装WindowsXP。除非您的手机是使用Intel处理器,但这种情况非常罕见。如果您需要在手机上...

如何查看硬盘序列号(windows如何查看硬盘序列号)

1.打开开始菜单栏,输入【cmd】点击【确定】;2.在命令窗口依次输入【diskpart】-【listdisk】-【selectdisk0】;3.选好要查看的硬盘后,接着输入【detaildi...

虚拟机安装win7教程(虚拟机安装win7教程图解)

1.首先,下载并安装虚拟机软件,如VMwareWorkstation、VirtualBox等。2.打开虚拟机软件,创建一个新的虚拟机。3.在创建虚拟机的过程中,选择安装Windows7专业版的IS...

系统脱敏法的操作程序如何

系统脱敏疗法(systematicdesensitization)又称交互抑制法,是由美国学者沃尔普创立和发展的。这种方法主要是诱导求治者缓慢地暴露出导致神经症焦虑、恐惧的情境,并通过心理的放松状态...

闪迪u盘低级格式化工具(闪迪u盘格式化分配单元大小)

闪迪U盘格式化后速度变慢的可能原因及解决方法如下:文件系统问题:格式化时选择的文件系统类型可能会影响U盘的性能。常见的文件系统类型包括FAT32、NTFS和exFAT等。如果文件系统类型不合适,可能会...

psd文件下载(psd格式下载网站)

  1、在photoshop中,不能通过置入的方法来加载PSD文件,因为,通过置入的方法加载PSD文件,它是以合并图层的方法把PSD文件加入,这样,就失去了PSD文件的所有图层信息。  2、在文档中想...

宏碁官网下载win7系统(宏碁官方系统)

宏基笔记本win8系统换成win7步骤:1、更改bios设置,关闭“SecureBoot”功能,启用传统的“LegacyBoot”。2、制作u启动U盘启动盘,下载win7系统安装包3、设置U盘启动...

如何重装系统win7旗舰版32位

首先下载制作一个带系统的启动u盘,然后按以下步骤安装:1、首先关闭电脑上面的杀毒软件,2、进入bios选择u盘启动。3、插入启动u盘重新启动电脑4、进入pe系统镜像环节,选择要安装的系统(32位),然...

应用程序发生异常0xe0000008

先查看一下对应的软件是不是出现了损坏,也可以重装此软件。我们还可以尝试通过修改注册表来解决。按Win+R(或者在开始菜单搜索框输入“运行”)打开运行,然后输入“regedit”回车,打开注册表恢复原来...

笔记本连接wifi显示无法连接网络

笔记本电脑连接wifi时提示无法连接到这个网络1、打开电脑“控制面板”,点击“网络连接”,选择本地连接,右键点击本地连接图标后选“属性”,在“常规”选项卡中双击“Internet协议(TCP/IP)...

windowsc盘清理大师(c盘清理大师怎么样)

 C盘清理大师是一款流氓软件,可不是windows10里自带。在你的电脑上出现这个软件一般情况下可以证明你使用的系统是盗版的,系统采用的是网上流传的系统镜像制作的。在网上流传这些系统镜像文件...

realtek没声音如何设置(realtek怎么调出来)

你给无线连接配IP地址呗第一步:下载驱动精灵软件。第二步:安装驱动精灵软件。1、在打开的驱动软件安装窗口,确定程序安装路径后,点击:一键安装;2、正在安装。第三步:更新驱动程序。1、安装非常迅速,已经...

腾达路由器手机端登录入口(腾达路由器手机端登录入口在哪)

腾达路由器使用192.168.0.1或tendawifi.com作为登录地址。登录管理员页面的步骤:1、手机连接到腾达路由器的wifi信号;2、在手机上打开浏览器,在地址栏输入192.168.0.1后...

取消回复欢迎 发表评论: