【Python篇】Python 函数综合指南——从基础到高阶

简介: 【Python篇】Python 函数综合指南——从基础到高阶

Python 函数综合指南

1. 函数介绍

在 Python 中,函数是构建程序的一个重要部分,它允许你封装逻辑并高效地重用代码。函数是组织良好的、可重复使用的代码块,用于执行单一的、相关的操作。函数为的应用提供了更好的模块化能力,并提高了代码的重用性。

1.1 什么是函数?

函数是一组相关语句的集合,用于执行特定的任务。函数有助于将程序分解为更小的模块化块。当程序越来越大时,函数使其更加有序和易于管理。

1.2 定义函数

在 Python 中,可以使用 def 关键字来定义函数。基本语法如下:

def function_name(parameters):
    """文档字符串"""
    语句块
  • function_name: 这是函数的名称。
  • parameters: 这些是传递给函数的参数。它们是可选的。
  • 文档字符串: 这是一个可选的字符串,用于描述函数的功能。它用三引号 """ 包围。
  • 语句块: 这些是构成函数主体的代码块。

示例:

def greet(name):
    """该函数用于向传入的参数名字打招呼"""
    print("你好, " + name + ". 早上好!")

1.3 调用函数

在定义函数之后,可以通过使用函数名称并加上括号来调用它,括号中可以选择性地传递参数。

greet('Alice')

1.4 函数参数

可以定义函数来接受参数,这些参数是传递给函数的值,用于影响函数的行为。

1.4.1 必需参数

传递给函数的参数在默认情况下是必需的。

def greet(name):
    print("你好, " + name)

greet('Alice')  # 正确
greet()         # 错误
1.4.2 默认参数

可以使用 = 操作符为参数定义默认值。

def greet(name="游客"):
    print("你好, " + name)

greet('Alice')  # 输出: 你好, Alice
greet()         # 输出: 你好, 游客


1.4.3 关键字参数

可以使用 parameter_name=value 语法传递参数。

def greet(name, message):
    print("你好, " + name + ". " + message)

greet(message="早上好!", name="Alice")


1.4.4 可变长度参数

有时可能需要定义一个可以接受可变数量参数的函数。可以使用 *args**kwargs 来实现。

  • *args: 非关键字可变长度参数
  • **kwargs: 关键字可变长度参数
def greet(*names):
    """该函数用于向 names 元组中的所有人打招呼"""
    for name in names:
        print("你好, " + name)

greet("Alice", "Bob", "Charlie")

2. Python 内置函数

Python 提供了许多内置函数,你可以直接使用。以下是一些最常用的内置函数:

2.1 字符串处理函数

  • len(): 返回字符串的长度。
  • str(): 将对象转换为字符串。
  • format(): 格式化字符串。
示例:
s = "你好, 世界!"
print(len(s))         # 输出: 9
print(str(123))       # 输出: '123'
print("我今年 {} 岁".format(25))  # 输出: 我今年 25 岁


2.2 数学函数

  • abs(): 返回一个数的绝对值。
  • min(): 返回所有输入值中的最小值。
  • max(): 返回所有输入值中的最大值。
示例:
print(abs(-5))        # 输出: 5
print(min(1, 2, 3))   # 输出: 1
print(max(1, 2, 3))   # 输出: 3

2.3 类型转换函数

  • int(): 将值转换为整数。
  • float(): 将值转换为浮点数。
  • bool(): 将值转换为布尔值。
  • list(): 将序列转换为列表。
示例:
print(int('10'))      # 输出: 10
print(float('10.5'))  # 输出: 10.5
print(bool(0))        # 输出: False
print(list("abc"))    # 输出: ['a', 'b', 'c']

2.4 输入和输出函数

  • input(): 从用户读取一行输入。
  • print(): 将指定消息输出到控制台。
示例:
name = input("请输入你的名字: ")
print("你好, " + name)

2.5 文件处理函数

  • open(): 打开一个文件并返回文件对象。
  • read(): 读取文件内容。
  • write(): 向文件写入内容。
  • close(): 关闭文件。
示例:
f = open("test.txt", "w")
f.write("你好, 世界!")
f.close()

f = open("test.txt", "r")
print(f.read())
f.close()

这一部分在之后文件操作会详细讲解


3. 匿名函数(Lambda 函数)

在 Python 中,可以使用 lambda 关键字创建小型匿名函数。Lambda 函数通常用于需要一个简单函数的场景,特别是在高阶函数中使用。

3.1 什么是 Lambda 函数?

Lambda 函数是没有名字的函数。它的定义比较简单,通常只用于简单的表达式中。其语法为:

lambda 参数1, 参数2, ... : 表达式

示例:

# 一个简单的 lambda 函数
add = lambda x, y: x + y
print(add(5, 3))  # 输出: 8

在上面的例子中,lambda x, y: x + y 定义了一个匿名函数,并将其赋值给 add 变量。之后,add(5, 3) 调用了这个 lambda 函数,返回结果 8

3.2 Lambda 函数的应用

Lambda 函数通常用于需要短小函数的场景,如排序、过滤等。

# 使用 lambda 函数对列表进行排序
points = [(1, 2), (3, 4), (5, 0)]
points.sort(key=lambda point: point[1])
print(points)  # 输出: [(5, 0), (1, 2), (3, 4)]


在这个例子中,lambda point: point[1] 用于指定排序的键,即每个元组的第二个元素。


4. 高阶函数

高阶函数是指能够接收其他函数作为参数,或者将函数作为返回值的函数。在 Python 中,常见的高阶函数包括 map()filter()reduce()

4.1 map() 函数

map() 函数用于将一个函数应用到一个序列(如列表)中的每个元素,并返回一个包含结果的新序列。

# 使用 map() 将每个数字乘以 2
numbers = [1, 2, 3, 4]
doubled = list(map(lambda x: x * 2, numbers))
print(doubled)  # 输出: [2, 4, 6, 8]

4.2 filter() 函数

filter() 函数用于过滤序列,保留满足条件的元素。它接收一个函数和一个序列,并返回一个包含函数返回 True 的元素的新序列。

# 使用 filter() 过滤出偶数
numbers = [1, 2, 3, 4, 5, 6]
evens = list(filter(lambda x: x % 2 == 0, numbers))
print(evens)  # 输出: [2, 4, 6]

4.3 reduce() 函数

reduce() 函数用于对序列中的元素进行累积。它接收一个函数和一个序列,并返回一个单一的累积结果。需要注意,reduce() 函数在 Python 3 中被移到了 functools 模块中。

from functools import reduce

# 使用 reduce() 计算列表元素的乘积
numbers = [1, 2, 3, 4]
product = reduce(lambda x, y: x * y, numbers)
print(product)  # 输出: 24

5. 递归函数

递归是指函数调用自身的编程技巧。递归可以用来解决许多编程问题,如计算阶乘、斐波那契数列等。

5.1 递归的基本概念

递归函数必须具备两个条件:

  1. 基本情况:定义一个最简单的情况,当满足这个情况时,函数将停止递归。
  2. 递归情况:函数调用自身以简化问题的规模。

示例:阶乘

def factorial(n):
    if n == 1:  # 基本情况
        return 1
    else:
        return n * factorial(n - 1)  # 递归调用

print(factorial(5))  # 输出: 120

在这个例子中,factorial() 函数通过递归计算了 5!,即 5 * 4 * 3 * 2 * 1

5.2 递归与迭代的对比

递归虽然优雅且易于理解,但在 Python 中,递归的深度是有限制的,过深的递归可能导致栈溢出。在某些情况下,递归可以被等效的迭代(如循环)所替代。

# 使用迭代计算阶乘
def factorial_iterative(n):
    result = 1
    for i in range(2, n + 1):
        result *= i
    return result

print(factorial_iterative(5))  # 输出: 120

在实际编程中,选择递归还是迭代取决于具体问题和性能需求。


6. 装饰器(Decorators)

装饰器是 Python 中的一种高级功能,它允许你在不修改函数代码的情况下增强或改变函数的行为。装饰器通常用于记录日志、权限验证、性能测试等场景。

6.1 什么是装饰器?

装饰器本质上是一个返回函数的高阶函数。它接收一个函数作为参数,并返回一个新的函数。

6.2 定义和使用装饰器

定义装饰器时,首先创建一个接收函数作为参数的函数。然后在内部定义一个包装函数,最后返回包装函数。

def my_decorator(func):
    def wrapper():
        print("Something is happening before the function is called.")
        func()
        print("Something is happening after the function is called.")
    return wrapper

@my_decorator
def say_hello():
    print("Hello!")

say_hello()

在这个例子中,@my_decorator 是装饰器语法糖,它等效于 say_hello = my_decorator(say_hello)。输出结果为:

Something is happening before the function is called.
Hello!
Something is happening after the function is called.

6.3 带参数的装饰器

装饰器还可以接受参数。这时,需要将装饰器再包装一层,使其成为一个接收参数的函数。

def repeat(n):
    def decorator(func):
        def wrapper(*args, **kwargs):
            for _ in range(n):
                func(*args, **kwargs)
        return wrapper
    return decorator

@repeat(3)
def say_hello():
    print("Hello!")

say_hello()


在这个例子中,say_hello() 会被执行三次。


7. 生成器函数(Generator Functions)

生成器是使用 yield 关键字的特殊函数。生成器不返回一个单一值,而是返回一个生成器对象,可以迭代生成多个值。


7.1 什么是生成器?

生成器允许你在函数执行时暂停,并在下一次调用时恢复执行。这使得生成器特别适用于处理大数据流或需要延迟计算的场景。

7.2 定义生成器函数

生成器函数与普通函数的定义类似,只不过使用 yield 而不是 return 返回值。

def countdown(n):
    while n > 0:
        yield n
        n -= 1

for i in countdown(5):
    print(i)

输出结果为:

5
4
3
2
1

7.3 生成器的应用场景

生成器常用于以下场景:

  • 处理大数据集:生成器按需生成数据,而不是一次性将所有数据加载到内存中。
  • 流式处理:生成器可以逐步生成数据,适合处理需要延迟计算的情况。
def fibonacci():
    a, b = 0, 1
    while True:
        yield a
        a, b = b, a + b

gen = fibonacci()
for _ in range(10):
    print(next(gen))

输出前十个斐波那契数列:

0
1
1
2
3
5
8
13
21
34

8. 闭包(Closures)

闭包是指函数内部定义的函数,该内部函数可以访问外部函数的变量,即使外部函数已经返回。

8.1 闭包的定义

闭包允许你在函数外部保留对局部变量的访问。这在需要延长局部变量的生命周期时非常有用。

def outer_func(x):
    def inner_func(y):
        return x + y
    return inner_func

add_five = outer_func(5)
print(add_five(10))  # 输出: 15

在这个例子中,inner_func 是一个闭包,它记住了 outer_func 的参数 x

8.2 闭包的使用场景

闭包常用于以下场景:

  • 封装:闭包可以隐藏数据,只暴露必要的接口。
  • 回调函数:闭包可以保存函数状态,在异步回调中非常有用。
def make_counter():
    count = 0
    def counter():
        nonlocal count
        count += 1
        return count
    return counter

counter = make_counter()
print(counter())  # 输出: 1
print(counter())  # 输出: 2
print(counter())  # 输出: 3

在这个例子中,count 变量被 counter 函数所捕获,每次调用 counter() 时,count 变量都会被保留和更新。


9. 异步函数(Asynchronous Functions)

Python 中的异步编程可以通过 asyncawait 关键字实现,使得我们可以编写非阻塞的代码,特别适合 I/O 密集型任务,如网络请求、文件操作等。

9.1 异步函数的基础

异步函数通过 async def 关键字定义,并且可以使用 await 来暂停执行,直到 await 后的操作完成。

import asyncio

async def say_hello():
    print("Hello...")
    await asyncio.sleep(1)
    print("...World!")

# 运行异步函数
asyncio.run(say_hello())

输出:

Hello...
...World!

9.2 使用 await 关键字

await 关键字用于挂起异步函数的执行,等待某个耗时操作完成。

async def fetch_data():
    print("Fetching data...")
    await asyncio.sleep(2)
    print("Data fetched!")

async def main():
    await fetch_data()
    print("Done!")

asyncio.run(main())

在这个例子中,await asyncio.sleep(2) 模拟了一个耗时操作,如网络请求或文件读取。

9.3 异步编程的应用场景

异步编程在以下场景中特别有用:

  • I/O 操作:如文件读取、网络请求、数据库查询等。
  • 并发任务:异步函数可以并发执行,充分利用 CPU 资源。
async def fetch_data(index):
    print(f"Fetching data {index}...")
    await asyncio.sleep(2)
    print(f"Data {index} fetched!")

async def main():
    tasks = [fetch_data(i) for i in range(5)]
    await asyncio.gather(*tasks)
    print("All data fetched!")

asyncio.run(main())

在这个例子中,asyncio.gather 用于并发执行多个异步任务。


10. 函数进阶知识

10.1 函数注解

Python 支持在函数定义时添加注解,以说明参数和返回值的预期类型。注解本身并不会影响函数行为,但可以用于文档生成或类型检查工具。

def greet(name: str) -> str:
    return "Hello, " + name

print(greet("Alice"))  # 输出: Hello, Alice


在这个例子中,name: str 表示 name 参数应为字符串类型,-> str 表示函数返回字符串。

10.2 可变参数函数

Python 支持定义可变参数的函数,允许传递任意数量的参数。

  • *args: 接收多个非关键字参数,作为一个元组传递给函数。
  • **kwargs: 接收多个关键字参数,作为一个字典传递给函数。
10.2.1 *args
  • *args 用于接收多个非关键字参数。这些参数会被打包成一个元组传递给函数。*args 允许函数接收任意数量的位置参数。

示例代码:

def my_func(*args):
    for arg in args:
        print(arg)

my_func(1, 2, 3)  
# 输出:
# 1
# 2
# 3
10.2.2. **kwargs
  • **kwargs 用于接收多个关键字参数,这些参数会被打包成一个字典传递给函数。**kwargs 允许函数接收任意数量的关键字参数。

示例代码:

def my_func(**kwargs):
    for key, value in kwargs.items():
        print(f"{key} = {value}")

my_func(name="Alice", age=30)
# 输出:
# name = Alice
# age = 30

通过使用 *args**kwargs,你可以编写更加灵活的函数,适应多种参数传递方式。

10.3 函数的柯里化

柯里化是一种将具有多个参数的函数转换为一系列单参数函数的技术。这在函数式编程中非常常见。

def multiply(x):
    def inner(y):
        return x * y
    return inner

double = multiply(2)
print(double(5))  # 输出: 10

在这个例子中,multiply(2) 返回一个函数 inner,该函数接受一个参数并返回其与 2 的乘积。


11. 高阶函数

高阶函数是指接收其他函数作为参数,或者将函数作为返回值的函数。在 Python 中,常见的高阶函数包括 map()filter()reduce()

def apply_func(func, value):
    return func(value)

def square(x):
    return x * x

result = apply_func(square, 5)
print(result)  # 输出: 25

在这个例子中,apply_func 是一个高阶函数,它接收另一个函数 square 作为参数,并应用于给定值 5

11.1 函数式编程

Python 支持函数式编程范式,它强调将计算描述为一系列函数应用。常用的函数式编程工具包括匿名函数、map-reduce 以及生成器表达式等。

numbers = [1, 2, 3, 4, 5]

# 使用 map 和 lambda 函数对列表中的每个元素平方
squares = list(map(lambda x: x * x, numbers))
print(squares)  # 输出: [1, 4, 9, 16, 25]

# 使用 filter 过滤出偶数
evens = list(filter(lambda x: x % 2 == 0, numbers))
print(evens)  # 输出: [2, 4]

# 使用 reduce 计算列表元素的乘积
from functools import reduce
product = reduce(lambda x, y: x * y, numbers)
print(product)  # 输出: 120

11.2 部分函数应用

部分函数应用(Partial Function Application)是指将函数的某些参数预先填入,从而创建一个新的函数。可以使用 functools.partial 来实现。

from functools import partial

def multiply(x, y):
    return x * y

double = partial(multiply, 2)  # 创建一个双倍函数
print(double(5))  # 输出: 10

在这个例子中,partial 创建了一个新函数 double,该函数始终将 2 作为第一个参数传递给 multiply


12. 结论

Python 函数是编程的基础模块,掌握函数的使用、定义和高级特性是编写高效、可重用代码的关键。,相信通过本篇博客你已经基本了解了从基础到高级的所有 Python 函数知识,包括内置函数、匿名函数、高阶函数、装饰器、生成器、闭包、异步函数等。希望这些知识能帮助你在实际编程中编写更为优雅和高效的 Python 代码。

以上就是关于【Python】Python 函数综合指南——从基础到高阶的内容啦,各位大佬有什么问题欢迎在评论区指正,您的支持是我创作的最大动力!❤️


相关文章
|
21天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
17天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2563 22
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
15天前
|
人工智能 IDE 程序员
期盼已久!通义灵码 AI 程序员开启邀测,全流程开发仅用几分钟
在云栖大会上,阿里云云原生应用平台负责人丁宇宣布,「通义灵码」完成全面升级,并正式发布 AI 程序员。
|
13天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
17天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1556 16
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
|
19天前
|
编解码 JSON 自然语言处理
通义千问重磅开源Qwen2.5,性能超越Llama
击败Meta,阿里Qwen2.5再登全球开源大模型王座
826 14
|
14天前
|
人工智能 开发框架 Java
重磅发布!AI 驱动的 Java 开发框架:Spring AI Alibaba
随着生成式 AI 的快速发展,基于 AI 开发框架构建 AI 应用的诉求迅速增长,涌现出了包括 LangChain、LlamaIndex 等开发框架,但大部分框架只提供了 Python 语言的实现。但这些开发框架对于国内习惯了 Spring 开发范式的 Java 开发者而言,并非十分友好和丝滑。因此,我们基于 Spring AI 发布并快速演进 Spring AI Alibaba,通过提供一种方便的 API 抽象,帮助 Java 开发者简化 AI 应用的开发。同时,提供了完整的开源配套,包括可观测、网关、消息队列、配置中心等。
621 7
|
7天前
|
Docker 容器
Docker操作 (五)
Docker操作 (五)
170 69
|
7天前
|
Docker 容器
Docker操作 (三)
Docker操作 (三)
167 69
|
19天前
|
人工智能 自动驾驶 机器人
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
过去22个月,AI发展速度超过任何历史时期,但我们依然还处于AGI变革的早期。生成式AI最大的想象力,绝不是在手机屏幕上做一两个新的超级app,而是接管数字世界,改变物理世界。
628 52
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界