如何在 Python 中装饰一个类?

开发 后端
在本篇中,我们将学习使用函数和类装饰器在 Python 中装饰一个类,Python 中的装饰器是修改现有函数或类的任何可调用对象。

它使用额外的 Python 语句修改旧对象并返回相同的引用。

例如,考虑下面的类,它有两个方法:__init__和 display。__init__方法在显示输出名称时初始化名称变量:

class Student:
def __init__(self, name):
self.name = name
def display(self):
print('Name:', self.name)

要在 Python 中装饰这个类,我们可以向该类添加新方法或修改现有方法,或者两者都做。

此外,在 Python 中有两种方法可以做到这一点,要么使用函数装饰器,要么使用类装饰器。

让我们一个一个看下例子。

使用函数装饰器装饰类

要使用函数装饰器来装饰类,接受类作为参数,修改其代码并在最后返回类。

def mydecorator(student):
#define a new display method
def newdisplay(self):
print('Name: ', self.name)
print('Subject: Programming')
#replace the display with newdisplay
student.display = newdisplay

#return the modified student
return student
@mydecorator
class Student:
def __init__(self, name):
self.name = name
def display(self):
print('Name:', self.name)
obj = Student('Pencil Programmer')
obj.display()
'''
Name: Pencil Programmer
Subject: Programming
'''

如果类中不存在 display 方法,则 newdisplay 将作为 display 方法添加到类中。

  •  由于类的引用在装饰器函数中是可用的,我们除了修改现有方法外,还可以为类添加新的属性和方法

使用类装饰器装饰类

要使用类装饰器装饰类,接受类的引用作为参数(在装饰器的__init__方法中),在 __call__方法中修改其代码,最后返回修改后的类的实例。

class Mydecorator:
#accept the class as argument
def __init__(self, student):
self.student = student

#accept the class's __init__ method arguments
def __call__(self, name):
#define a new display method
def newdisplay(self):
print('Name: ', self.name)
print('Subject: Python')

#replace display with newdisplay
self.student.display = newdisplay

#return the instance of the class
obj = self.student(name)
return obj
@Mydecorator
class Student:
def __init__(self, name):
self.name = name

def display(self):
print('Name: ', self.name)
obj = Student('Pencil Programmer')
obj.display()
'''
Name: Pencil Programmer
Subject: Python
'''

这里唯一的区别是我们返回的是对象的引用而不是类引用。

原文:​​https://pencilprogrammer.com/decorate-python-class/​

责任编辑:庞桂玉 来源: python运维技术
相关推荐

2021-02-14 13:38:17

Python开发函数

2024-04-18 10:23:35

装饰器Python

2019-05-21 13:55:22

Python编程语言游戏

2022-08-14 08:29:21

npmNode

2016-12-07 17:45:44

Linux文件

2024-04-11 08:30:05

JavaScript数组函数

2019-09-10 09:12:54

2012-03-14 11:08:32

JavaJLayer

2021-11-01 12:13:53

Linux僵尸进程

2021-09-14 12:34:33

LinuxLinux终端

2017-02-10 20:00:17

Linux共享目录命令

2022-05-10 09:12:16

TypeScript装饰器

2021-05-28 18:12:51

C++设计

2011-04-01 09:49:54

Python

2010-02-01 17:50:32

Python装饰器

2021-11-15 10:35:46

Python线程代码

2019-08-12 09:55:10

GitHub项目终端

2016-07-18 10:51:19

操作系统LinuxWindows

2021-07-02 07:18:19

Goresults通道类型
点赞
收藏

51CTO技术栈公众号