当前位置: 首页 > news >正文

1.2.2 高级特性详解——AI教你学Django

1.2.2 高级特性详解(Django 基础学习细节)

Python 的高级特性如装饰器、生成器、迭代器和上下文管理器,是提升代码复用性、灵活性和可维护性的利器。Django 中间件、视图、ORM等大量用到这些技术。下面详细讲解每一项,并给出丰富代码示例。

一、装饰器(Decorator)

装饰器是对函数或类进行“包装”以增强功能的语法,常用于日志、权限、缓存、性能统计等场景。

1. 函数装饰器

1.1 基本函数装饰器
def my_decorator(func):def wrapper(*args, **kwargs):print("函数开始执行")result = func(*args, **kwargs)print("函数执行结束")return resultreturn wrapper@my_decorator
def greet(name):print(f"Hello, {name}")greet("Alice")
# 输出:
# 函数开始执行
# Hello, Alice
# 函数执行结束
1.2 多个装饰器(从下往上执行)
def deco1(func):def wrapper(*args, **kwargs):print("deco1")return func(*args, **kwargs)return wrapperdef deco2(func):def wrapper(*args, **kwargs):print("deco2")return func(*args, **kwargs)return wrapper@deco1
@deco2
def foo():print("foo body")foo()
# 输出:
# deco1
# deco2
# foo body
1.3 保持原函数元数据(推荐用 functools.wraps)
import functoolsdef log(func):@functools.wraps(func)def wrapper(*args, **kwargs):print(f"call {func.__name__}")return func(*args, **kwargs)return wrapper@log
def add(a, b):"Adds two numbers"return a + bprint(add.__name__)      # add
print(add.__doc__)       # Adds two numbers

2. 参数化装饰器(带参数的装饰器)

def repeat(n):def decorator(func):def wrapper(*args, **kwargs):for _ in range(n):func(*args, **kwargs)return wrapperreturn decorator@repeat(3)
def hi():print("Hi!")hi()
# 输出三次 Hi!

3. 类装饰器

  • 用类实现装饰器,适合复杂状态管理
class Counter:def __init__(self, func):self.func = funcself.count = 0def __call__(self, *args, **kwargs):self.count += 1print(f"调用次数: {self.count}")return self.func(*args, **kwargs)@Counter
def show(name):print(f"Hello, {name}")show("Tom")  # 调用次数: 1
show("Ann")  # 调用次数: 2

二、生成器与 yield、迭代器

1. 生成器函数(yield)

  • yield 返回一个生成器对象,能“惰性”产出数据,节省内存。
def count_up(n):i = 1while i <= n:yield ii += 1gen = count_up(3)
print(next(gen))  # 1
print(next(gen))  # 2
print(next(gen))  # 3
# next(gen)  # StopIteration异常
1.1 用 for 遍历生成器
for num in count_up(5):print(num)
# 输出 1 2 3 4 5

2. 列表生成 vs 生成器表达式

lst = [x*x for x in range(1000)]     # 占用大量内存
gen = (x*x for x in range(1000))     # 生成器,内存高效for val in gen:print(val)

3. 自定义迭代器

  • 实现 __iter____next__ 方法
class MyRange:def __init__(self, start, end):self.cur = startself.end = enddef __iter__(self):return selfdef __next__(self):if self.cur < self.end:val = self.curself.cur += 1return valelse:raise StopIterationfor i in MyRange(10, 13):print(i)
# 输出: 10 11 12

三、上下文管理器(with 语法)、自定义

1. 内建上下文管理器:文件操作

with open("test.txt", "w") as f:f.write("hello world")
# 自动关闭文件,无需手动 f.close()

2. 自定义上下文管理器(类实现)

  • 需实现 __enter____exit__ 方法
class MyContext:def __enter__(self):print("进入上下文")return selfdef __exit__(self, exc_type, exc_val, exc_tb):print("离开上下文")with MyContext():print("处理中")
# 输出:
# 进入上下文
# 处理中
# 离开上下文

3. 异常处理

  • __exit__ 接收异常信息,能决定是否吞掉异常
class SafeOpen:def __init__(self, filename):self.filename = filenameself.file = Nonedef __enter__(self):self.file = open(self.filename, "w")return self.filedef __exit__(self, exc_type, exc_val, exc_tb):self.file.close()if exc_type:print(f"发生异常: {exc_val}")return True  # 异常不再向外抛出with SafeOpen("demo.txt") as f:f.write("Hello")raise Exception("测试异常")
# 输出: 发生异常: 测试异常

4. 使用 contextlib 简化上下文管理器

from contextlib import contextmanager@contextmanager
def tag(name):print(f"<{name}>")yieldprint(f"</{name}>")with tag("div"):print("这是内容")
# 输出:
# <div>
# 这是内容
# </div>

四、实用小结

  • 装饰器让函数/类扩展更灵活,Django 中间件、权限控制大量用到
  • 生成器和迭代器能处理大数据流,节省内存,Django QuerySet 就是惰性迭代器
  • 上下文管理器保证资源安全释放,是处理文件、数据库连接等场景的最佳选择
  • 推荐掌握各类高级特性,可在实际项目中写出更优雅、可维护的代码
http://www.dtcms.com/a/278330.html

相关文章:

  • 【图片识别改名】水印相机拍的照片如何将照片的名字批量改为水印内容?图片识别改名的详细步骤和注意事项
  • 【WPF】WPF 自定义控件 实战详解,含命令实现
  • 【零基础入门unity游戏开发——unity3D篇】3D光源之——unity6的新功能Adaptive Probe Volumes(APV)(自适应探针体积)
  • ACL流量控制实验
  • 深入了解linux系统—— 进程信号的产生
  • 客户端主机宕机,服务端如何处理 TCP 连接?详解
  • EasyExcel实现Excel文件导入导出
  • VScode链接服务器一直卡在下载vscode服务器,无法连接成功
  • C++之哈希表的基本介绍以及其自我实现(开放定址法版本)
  • 多客户端 - 服务器结构-实操
  • 史上最清楚!读者,写者问题(操作系统os)
  • 基于 Gitlab、Jenkins与Jenkins分布式、SonarQube 、Nexus 的 CiCd 全流程打造
  • SQL创建三个表
  • 从 JSON 到 Python 对象:一次通透的序列化与反序列化之旅
  • Dubbo高阶难题:异步转同步调用链上全局透传参数的丢失问题
  • Selenium动态网页爬虫编写与解释
  • 【微信小程序】
  • 当你在 Git 本地提交后,因权限不足无法推送到服务端,若想撤销本次提交,可以根据不同的需求选择合适的方法,下面为你介绍两种常见方式。
  • 清除 Android 手机 SIM 卡数据的4 种简单方法
  • 云手机常见问题解析:解决延迟、掉线等困扰
  • 云手机的多重用途:从游戏挂机到办公自动化
  • kafka的部署
  • 从零实现浏览器摄像头控制与视频录制:基于原生 JavaScript 的完整指南
  • 如何将数据从一部手机传输到另一部手机?
  • 马蹄集 BD202401补给
  • C#中如何阻止硬件休眠
  • Vue 低代码可视化表单设计器 FcDesigner v3.3 版本发布!表格布局升级+精细化权限控制
  • JDK1.8 ReentrantLock相关源码
  • 代数基本定理
  • 多模态数据处理新趋势:阿里云ODPS技术栈深度解析与未来展望