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实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

python判断文件是否存在常用的几种方式

《python判断文件是否存在常用的几种方式》在Python中我们在读写文件之前,首先要做的事情就是判断文件是否存在,否则很容易发生错误的情况,:本文主要介绍python判断文件是否存在常用的几种... 目录1. 使用 os.path.exists()2. 使用 os.path.isfile()3. 使用

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作