Python基础篇_修饰符(Decorators)【中】

2024-02-09 07:12

本文主要是介绍Python基础篇_修饰符(Decorators)【中】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇:Python基础篇_修饰符【上】(@decorator、@classmethod、@staticmethod)

 Python基础篇_修饰符(Decorators)[中]

  • Python基础篇_修饰符【中】
    • 一、修饰符一般特点
    • 二、常用的修饰符以及用法举例
      • 4) @property,属性装饰器;@<attribute_name>.setter,属性设置
      • 5) @<attribute_name>.deleter,删除属性
      • 6) @functools.lru_cache(maxsize=None),值缓存

Python基础篇_修饰符【中】

    Python中有多种修饰符,这些修饰符用于指定方法的特殊行为或属性,也是用于修改函数行为的特殊参数。

一、修饰符一般特点

  1. 修饰符只能用于类定义中,不能用于普通函数中
  2. 属性修饰符是可叠加的,也就是说,一个方法可以同时被多个属性修饰符修饰

二、常用的修饰符以及用法举例

4) @property,属性装饰器;@<attribute_name>.setter,属性设置

    @property用于将方法变成属性。这允许我们以类似访问属性(即直接通过点运算符)的方式来调用方法,而不需要使用括号。当我们将@property装饰一个方法时,这个方法变成了所谓的"getter",它在每次属性被读取时都会执行,并且会返回值。

    同时,我们还使用@<attribute_name>.setter,允许我们为属性提供一个设置值的方法。如果一个@property没有与之对应的@<attribute_name>.setter,则此属性为只读属性。

示例1:只读属性

class Person:def __init__(self, name):self._name = name@propertydef full_name(self):return self._name + " Doe"# 在这个例子中,我们定义了一个人的类,其中有一个只读属性`full_name`。
# 每次访问这个属性时,它都会返回带有" Doe"后缀的全名。
# 我们没有为这个属性提供setter,所以它是一个只读属性。

示例2:带有计算值的属性

class Circle:def __init__(self, radius):self._radius = radius@propertydef area(self):return 3.14 * self._radius ** 2@area.setterdef area(self, new_area):self._radius = new_area / 3.14 ** 0.5# 在这个例子中,我们有一个圆,它有一个半径属性。
# 我们还定义了一个计算面积的getter方法。为了设置面积
# 我们还定义了一个setter方法,它会根据给定的面积重新计算半径。

示例3:带有多个setter的属性

class Rectangle:def __init__(self, width, height):self._width = widthself._height = height@propertydef area(self):return self._width * self._height@area.setter  # 这个setter同时用于width和height的修改def area(self, new_area):width = new_area / self._height if self._height != 0 else 0height = new_area / self._width if self._width != 0 else 0self._width = widthself._height = height# 在这个例子中,我们有一个矩形类,它有两个属性:宽度和高度。
# 我们还定义了一个计算面积的getter方法。
# 为了设置面积,我们还定义了一个setter方法,它会根据给定的面积重新计算宽度和高度。
# 注意,这个setter方法同时用于宽度和高度属性的设置。        

5) @<attribute_name>.deleter,删除属性

    @<attribute_name>.deleter 是一个用于删除属性的装饰器,通常与 @property@<attribute_name>.setter 一起使用。它允许你定义一个方法来删除属性值。

示例1:删除Person类的name属性值

class Person:def __init__(self, name):self._name = name@propertydef name(self):return self._name@name.setterdef name(self, new_name):self._name = new_name@name.deleterdef name(self):print("Deleting name")del self._nameaPerson = Person('张三')
print(aPerson.name)
aPerson.name = '李四'
print(aPerson.name)
del aPerson.name
print(aPerson.name)
# 执行结果
张三
李四
Deleting name
AttributeError: 'Person' object has no attribute '_name'

示例2:删除User类的username属性值

class User:def __init__(self, username):self._username = username@propertydef username(self):return self._username@username.setterdef username(self, new_username):if not isinstance(new_username, str):raise ValueError("Username must be a string")self._username = new_username@username.deleterdef username(self):print("Deleting username")del self._usernameUser = User('张三')
print(User.username)
User.name = '李四'
print(User.username)
del User.name
print(User._username)
# 执行结果
张三
李四
Deleting username
AttributeError: 'User' object has no attribute '_username'

6) @functools.lru_cache(maxsize=None),值缓存

    functools.lru_cache(maxsize=None) 是 Python 的内置函数,用于实现最近最少使用 (Least Recently Used, LRU) 缓存策略。LRU 缓存是一种常见的缓存替换策略,用于决定当缓存达到其最大容量时应该丢弃哪个元素。最近最少使用的元素将被丢弃。

    lru_cache 可以用于任何可调用的对象(例如函数)。当一个函数被装饰后,它会在第一次调用时被执行,并且结果会被缓存。在随后的调用中,如果函数的参数相同,它将直接从缓存中返回结果,而不会再次执行函数。

    maxsize 参数指定了缓存的最大容量。如果将其设置为 None,则表示缓存可以无限增长。

    在计算密集型函数中,缓存之前计算的结果,在以后的调用中直接使用它们,而不需要重新计算。这样即使在多次调用计算密集型函数时,也可以快速地获取结果,而不需要重复进行计算,可以大大提高其性能。

示例1:使用缓存计算斐波那契数列

import functools@functools.lru_cache(maxsize=5)     # 缓存前5个斐波那契数
def fibonacci(n):if n < 2:return nreturn fibonacci(n-1) + fibonacci(n-2)# 计算斐波那契数列的第 10 个数
print(fibonacci(10))  # 输出: 55

示例2:使用缓存计算子集合组合

import functools@functools.lru_cache(maxsize=None) # None表示缓存无上限
def combinations(numbers):if len(numbers) == 0:return [[]]  else:results = []for i in range(len(numbers)):results += [x + [numbers[i]] for x in combinations(numbers[:i] + numbers[i+1:])]return results# 测试函数
numbers = [1, 2, 3]
print(combinations(numbers))  
# 执行结果
[[], [1], [2], [1, 2], [3], [1, 3], [2, 3], [1, 2, 3]]

示例3:使用缓存计算字符串所有子串

import functools@functools.lru_cache(maxsize=None) # None表示缓存无上限
def combinations(strings):if len(strings) == 0:return [""]else:results = []for i in range(len(strings)):results += [x + strings[i] for x in combinations(strings[:i] + strings[i+1:])]return results# 测试函数
strings = ["a", "b", "c"]
print(combinations(strings))  
# 执行结果 
['', 'a', 'b', 'c', 'ab', 'ac', 'bc', 'abc']

may the odds be ever in your favor ~

这篇关于Python基础篇_修饰符(Decorators)【中】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/693501

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e