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

30天学会Python编程:6. Python函数编程

off999 2025-09-12 01:26 34 浏览 0 评论

6.1 函数基础

6.1.1 函数定义与调用

函数定义语法

def function_name(parameters):
    """文档字符串(可选)"""
    # 函数体
    return [expression]  # 可选

函数调用原理

6.1.2 函数组成要素

表6-1 函数核心组成要素

要素

说明

示例

函数名

标识函数的名称

calculate_area

参数

函数接收的输入

radius

函数体

执行的代码块

return 3.14 * radius**2

返回值

函数输出的结果

78.5

文档字符串

函数说明文档

"""计算圆面积"""

6.1.3 简单函数示例

def greet(name):
    """返回个性化问候语
    
    Args:
        name (str): 用户名
        
    Returns:
        str: 问候字符串
    """
    return f"Hello, {name.capitalize()}!"

# 调用示例
print(greet("alice"))  # Hello, Alice!

6.2 参数传递

6.2.1 参数类型

四种参数类型

参数组合顺序

def func(positional, keyword=value, *args, **kwargs):
    pass

6.2.2 参数传递示例

# 位置参数
def power(base, exponent):
    return base ** exponent

# 关键字参数
print(power(exponent=3, base=2))  # 8

# 默认参数
def connect(host, port=3306, timeout=10):
    print(f"连接到 {host}:{port}, 超时:{timeout}s")

# 可变位置参数(*args)
def sum_numbers(*numbers):
    return sum(numbers)

# 可变关键字参数(**kwargs)
def build_profile(**info):
    for key, value in info.items():
        print(f"{key}: {value}")

6.2.3 参数解包

# 列表/元组解包为位置参数
args = [3, 4]
print(power(*args))  # 81

# 字典解包为关键字参数
kwargs = {"base": 2, "exponent": 5}
print(power(**kwargs))  # 32

6.3 返回值与作用域

6.3.1 返回值特性

多返回值实现

def analyze_number(n):
    return n**2, n**3, abs(n)

square, cube, absolute = analyze_number(-3)

返回函数

def create_multiplier(factor):
    def multiplier(x):
        return x * factor
    return multiplier

double = create_multiplier(2)
print(double(5))  # 10

6.3.2 变量作用域

LEGB规则

作用域示例

x = "global"

def outer():
    x = "enclosing"
    def inner():
        x = "local"
        print(x)  # local
    inner()
    print(x)  # enclosing

outer()
print(x)  # global

6.4 高阶函数

6.4.1 常用高阶函数

map/filter/reduce

numbers = [1, 2, 3, 4]

# map应用函数到每个元素
squares = list(map(lambda x: x**2, numbers))

# filter过滤元素
evens = list(filter(lambda x: x%2==0, numbers))

# reduce累积计算
from functools import reduce
product = reduce(lambda x,y: x*y, numbers)

6.4.2 函数作为参数

def apply_operation(func, a, b):
    """应用指定操作到两个数"""
    return func(a, b)

result = apply_operation(lambda x,y: x+y, 3, 4)  # 7

6.5 闭包与装饰器

6.5.1 闭包实现

def counter():
    count = 0
    def increment():
        nonlocal count
        count += 1
        return count
    return increment

c = counter()
print(c(), c(), c())  # 1 2 3

6.5.2 装饰器应用

简单装饰器

def timer(func):
    """测量函数执行时间"""
    import time
    def wrapper(*args, **kwargs):
        start = time.time()
        result = func(*args, **kwargs)
        end = time.time()
        print(f"{func.__name__}执行耗时: {end-start:.4f}s")
        return result
    return wrapper

@timer
def long_running_task(n):
    return sum(i*i for i in range(n))

带参数装饰器

def repeat(times):
    """重复执行函数"""
    def decorator(func):
        def wrapper(*args, **kwargs):
            for _ in range(times):
                result = func(*args, **kwargs)
            return result
        return wrapper
    return decorator

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

6.6 函数式编程工具

6.6.1 functools模块

from functools import partial, lru_cache

# 偏函数
square_root = partial(power, exponent=0.5)
print(square_root(9))  # 3.0

# 缓存装饰器
@lru_cache(maxsize=128)
def fibonacci(n):
    if n < 2:
        return n
    return fibonacci(n-1) + fibonacci(n-2)

6.6.2 生成器函数

def fibonacci_sequence(limit):
    """生成斐波那契数列"""
    a, b = 0, 1
    while a < limit:
        yield a
        a, b = b, a + b

print(list(fibonacci_sequence(100)))
# [0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89]

6.7 综合应用举例

案例1:数据管道处理

def data_pipeline():
    """数据处理管道示例"""
    # 数据源
    raw_data = ["10", "20", "30", "abc", "40"]
    
    # 处理步骤
    processed = (
        map(str.strip, raw_data),          # 去空格
        filter(str.isdigit, _),           # 过滤数字
        map(int, _),                      # 转整数
        map(lambda x: x*2, _),            # 数值加倍
        list                              # 转为列表
    )
    
    for step in processed:
        print(f"当前步骤: {step.__name__ if hasattr(step, '__name__') else str(step)}")
        data = step(data) if 'data' in locals() else step
        print(f"处理结果: {data}")
    
    return data

print("最终结果:", data_pipeline())

案例2:权限检查装饰器

def permission_required(permission):
    """权限检查装饰器"""
    def decorator(func):
        def wrapper(user, *args, **kwargs):
            if user.get("permissions", 0) & permission != permission:
                raise PermissionError("权限不足")
            return func(user, *args, **kwargs)
        return wrapper
    return decorator

# 权限定义
READ = 0b001
WRITE = 0b010
ADMIN = 0b100

@permission_required(READ | WRITE)
def edit_document(user, document):
    print(f"{user['name']}正在编辑{document}")

# 使用示例
user = {"name": "Alice", "permissions": 0b011}
try:
    edit_document(user, "重要文件")
except PermissionError as e:
    print(e)

6.8 学习路线图

6.9 学习总结

  1. 核心要点
  2. 理解函数定义与调用机制
  3. 掌握各种参数传递方式
  4. 熟练使用装饰器模式
  5. 了解函数式编程思想
  6. 实践建议
  7. 函数保持单一职责原则
  8. 合理使用默认参数提高可用性
  9. 为公共函数添加文档字符串
  10. 使用装饰器分离横切关注点
  11. 进阶方向
  12. 协程与异步函数
  13. 函数签名检查(inspect模块)
  14. 描述符协议实现
  15. 元类编程
  16. 常见陷阱
  17. 可变默认参数问题
  18. 闭包变量捕获时机
  19. 装饰器堆叠顺序
  20. 名称空间污染

持续更新Python编程学习日志与技巧,敬请关注!


#编程# #python# #在头条记录我的2025#


相关推荐

2017年联想笔记本电脑有几款

17年的笔记本电脑可以勉强安装一下win10系统试试。关键看你的内存有多少,内存大于4个G的话可以安装win10速度不会太慢。最好是安装win7系统,这样能发挥你这台电脑的所有的性能,你用起来也会感觉...

当前显卡排名(当下显卡排行)

101、Irispro5802、Iris62002、Iris52004、UHD630/6205、HD6306、HD5307、HD46008、HD44009、HD420010、HD40...

win10专业版激活变成企业版(win10专业版激活变成企业版怎么办)

win10永久激活密钥很少,一旦网上有分享,等你拿到时就超过期限了,一般是要购买。激活win10系统可以使用激活工具:win10激活工具下载一、win10专业版产品密钥NXRQM-CXV6P-PBGV...

ghostwinxp下载纯净版(ghost win7纯净版下载)

可以下载的,现在官网和其他网站上都可以下载xp原版的。可以通过以下步骤下载我的世界游戏到xp系统中:1.首先打开你的浏览器软件,搜索关键字“我的世界xp版下载”,找到可靠下载地址;2.从下载页面下...

惠普完整版驱动(惠普最新驱动)

惠普官方的标准操作:HP1050安装驱动步骤:一:准备:拿出驱动光盘放入光驱或到HP官网下载完整版驱动。二:不要插USB数据线或插上线打印机电源不要开,安装完整版驱动,当程序提示插入USB数据线时,插...

浏览器最好用的(浏览器最好用的插件)

一、谷歌浏览器谷歌浏览器是公认最好用的,这个可以从市场占有率看出端倪,超过三分之二的用户使用谷歌浏览器。Chrome浏览器以简洁快速著称,不管是普通用户还是开发人员,chrome浏览器都是首选。Chr...

fast路由器6位初始密码(fast路由器的密码)

答:fast路由器初始密码是admin;新款的迅捷无线路由器,管理界面没有初始密码。查看迅捷无线路由器底部标签,标签上标注了admin,说明初始密码就是admin;如果没有,说明该路由器没有初始密码。...

硬盘恢复软件哪个好(硬盘 恢复软件)

迷你兔数据恢复工具:支持恢复硬盘丢失的数据Pc3000数据恢复软件是一款非常专业的硬盘修复工具,能够对电脑硬盘资料数据进行修复,通过使用这个软件可以解决硬盘数据丢失故障,是一个用户进行硬盘资料修复好帮...

十大品牌监控摄像头排名(十大品牌监控摄像头排名第一)

答:1、华为/HUAWEI9.92、小米/MI9.63、罗技/Logitech9.64、海康威视/HIKVISION9.25、乔安/Jooan9.26、普联/TP-LINK9.27、乐橙8.98、萤石...

360手机助手老旧版本大全(360手机助手 老版本)

在设置里面找到历史记录就可能查看360手机助手·换机神器是安卓系统的换机软件,因为苹果的换机软件是爱思。1、打开360手机卫士,登陆账号,点击账号。2、进入个人中心,点击账户安全,在密保工具中,点击解...

系统应用工程师(系统工程的应用)

信息软件系统工程师有前途,毕业以后可以从事软件开发,软件系统的维护,运营等等,和计算机有关的工作内容,因为计算机专业可以说是一个非常热门的专业,很多的大型企业公司基本上都是以计算机研发为主的,薪资福利...

qq恢复系统常见问题(qq恢复系统常见问题及答案)

QQ好友恢复系统一直显示服务器频繁有可能是系统的问题,你的qq重新更新一下,或者你卸载了重新下载一下就有可能好了。您好,很高兴为您解答:您可以试试清空下IE内存,然后关掉不必要的程序,尽量在电脑运...

win10自带的office不见了(win10自带的office在哪个文件夹)

win10系统的office在电脑硬盘office的安装目录里,具体打开安装目录的操作如下:1、首先我们右键点击word,打开方式,选择默认程序打开。2、在默认框打钩,点击【浏览】。3、打开你安装of...

华为官网序列号查询入口(华为官网序列号查询入口手写笔)
  • 华为官网序列号查询入口(华为官网序列号查询入口手写笔)
  • 华为官网序列号查询入口(华为官网序列号查询入口手写笔)
  • 华为官网序列号查询入口(华为官网序列号查询入口手写笔)
  • 华为官网序列号查询入口(华为官网序列号查询入口手写笔)
手机主题美化包(手机主题美化包下载)
  • 手机主题美化包(手机主题美化包下载)
  • 手机主题美化包(手机主题美化包下载)
  • 手机主题美化包(手机主题美化包下载)
  • 手机主题美化包(手机主题美化包下载)

取消回复欢迎 发表评论: