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

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

off999 2025-09-12 01:26 54 浏览 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#


相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: