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

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

itomcoil 2025-06-12 13:20 12 浏览

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#


相关推荐

selenium(WEB自动化工具)

定义解释Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。支持的浏览器包括IE(7,8,9,10,11),MozillaF...

开发利器丨如何使用ELK设计微服务中的日志收集方案?

【摘要】微服务各个组件的相关实践会涉及到工具,本文将会介绍微服务日常开发的一些利器,这些工具帮助我们构建更加健壮的微服务系统,并帮助排查解决微服务系统中的问题与性能瓶颈等。我们将重点介绍微服务架构中...

高并发系统设计:应对每秒数万QPS的架构策略

当面试官问及"如何应对每秒几万QPS(QueriesPerSecond)"时,大概率是想知道你对高并发系统设计的理解有多少。本文将深入探讨从基础设施到应用层面的解决方案。01、理解...

2025 年每个 JavaScript 开发者都应该了解的功能

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发。1.Iteratorhelpers开发者...

JavaScript Array 对象

Array对象Array对象用于在变量中存储多个值:varcars=["Saab","Volvo","BMW"];第一个数组元素的索引值为0,第二个索引值为1,以此类推。更多有...

Gemini 2.5编程全球霸榜,谷歌重回AI王座,神秘模型曝光,奥特曼迎战

刚刚,Gemini2.5Pro编程登顶,6美元性价比碾压Claude3.7Sonnet。不仅如此,谷歌还暗藏着更强的编程模型Dragontail,这次是要彻底翻盘了。谷歌,彻底打了一场漂亮的翻...

动力节点最新JavaScript教程(高级篇),深入学习JavaScript

JavaScript是一种运行在浏览器中的解释型编程语言,它的解释器被称为JavaScript引擎,是浏览器的一部分,JavaScript广泛用于浏览器客户端编程,通常JavaScript脚本是通过嵌...

一文看懂Kiro,其 Spec工作流秒杀Cursor,可移植至Claude Code

当Cursor的“即兴编程”开始拖累项目质量,AWS新晋IDEKiro以Spec工作流打出“先规范后编码”的系统工程思维:需求-设计-任务三件套一次生成,文档与代码同步落地,复杂项目不...

「晚安·好梦」努力只能及格,拼命才能优秀

欢迎光临,浏览之前点击上面的音乐放松一下心情吧!喜欢的话给小编一个关注呀!Effortscanonlypass,anddesperatelycanbeexcellent.努力只能及格...

JavaScript 中 some 与 every 方法的区别是什么?

大家好,很高兴又见面了,我是姜茶的编程笔记,我们一起学习前端相关领域技术,共同进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力在JavaScript中,Array.protot...

10个高效的Python爬虫框架,你用过几个?

小型爬虫需求,requests库+bs4库就能解决;大型爬虫数据,尤其涉及异步抓取、内容管理及后续扩展等功能时,就需要用到爬虫框架了。下面介绍了10个爬虫框架,大家可以学习使用!1.Scrapysc...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

pip3 install pyspider报错问题解决

运行如下命令报错:>>>pip3installpyspider观察上面的报错问题,需要安装pycurl。是到这个网址:http://www.lfd.uci.edu/~gohlke...

PySpider框架的使用

PysiderPysider是一个国人用Python编写的、带有强大的WebUI的网络爬虫系统,它支持多种数据库、任务监控、项目管理、结果查看、URL去重等强大的功能。安装pip3inst...

「机器学习」神经网络的激活函数、并通过python实现激活函数

神经网络的激活函数、并通过python实现whatis激活函数感知机的网络结构如下:左图中,偏置b没有被画出来,如果要表示出b,可以像右图那样做。用数学式来表示感知机:上面这个数学式子可以被改写:...