property装饰器函数 @classmethod @staticmethod isinstance和issubclass

property函数   让方法伪装成属性   还有一系列的装饰器函数

 1 class Goods:
 2     __discount = 0.8
 3     def __init__(self,price):
 4         self.__price = price
 5         self.name = ‘apple‘
 6
 7     @property                 #伪装成属性
 8     def price(self):
 9         return self.__price * Goods.__discount
10
11     @price.setter             #修改折扣
12     def price(self,new):
13         self.__price = new
14
15     @price.deleter            #删除方法
16     def price(self):
17         del self.__price
18 apple = Goods(10)
19 print(apple.price)
20 print(apple.__dict__)
21 del apple.price
22 apple.price = 8
23 print(apple.price)
24
25 # print(apple.__dict__)
26 # del apple.name
27 # print(apple.__dict__)

一个方法被伪装成属性之后,应该可以执行一个属性的增删改查操作

那么增加和修改 就对应这被setter 装饰的方法:这个方法又必须传一个参数比如new,表示赋值的的是等号右边的值

删除一个属性 对应着被 deleter 装饰的方法,这个方法并不能再执行的时候真的删除这个属性,而是你代码中执行什么 就有什么效果

class A:
    def __init__(self):
        self.__f = open(‘aaa‘,‘w‘)

    @property
    def f(self):
        return self.__f

    @f.deleter
    def f(self):
        self.__f.close()
        del self.__f                       # 主要注意关闭文件句柄

@classmethod

class Goods:
    __discount = 0.8           # 静态属性
    def __init__(self,price):
        self.__price = price   #  对象属性
        self.name = ‘apple‘
    @property
    def price(self):
        print(self)
        return self.__price * Goods.__discount
    @classmethod
    def change_discount(cls,new):       # 类方法  修改了静态属性
        cls.__discount = new
Goods.change_discount(0.7)
print(Goods.__dict__) 
apple = Goods(10)banana = Goods(20)apple.change_discount(0.7)print(apple.price)print(Goods)print(banana.price)

#类方法的特点

只使用类中的资源,并且这个资源可以直接用类名引用使用(不用对象名去调用),那这个方法应该被称为类方法

@staticmethod

class Student:

    @staticmethod
    def login(usr,pwd):
        print(‘IN LOGIN‘,usr,pwd)

Student.login(‘user‘,‘pwd‘)             变成一个普通函数

类:    静态属性         类  所有的对象都统一拥有的属性    类方法           类  如果这个方法涉及到操作静态属性、类方法、静态方法                            cls 表示类    静态方法         类  普通方法,不使用类中的命名空间也不使用对象的命名空间   : 一个普通的函数    没有默认参数    方法             对象                                                                            self 表示对象    property方法     对象                                                                            slef 表示对象

isinstance 检测对象与类之间的关系

issubclass 检测类与类之间的关系

class A:
    conut = 1                   #静态属性

    def __init__(self,name):   #方法
        self.__name= name
    # @property                   #property方法
    # def name(self):
    #     return self.__name
    @classmethod
    def ppcount(cls,new):      #类方法
        cls.conut = new
    @staticmethod       #静态方法  变成普通的函数   我的话来说 就是直接退化变垃圾了
    def func(a):
        print(‘alex‘)
p1 = A(‘ALEC‘)
print(p1.__dict__)
print(p1._A__name)

原文地址:https://www.cnblogs.com/single82/p/9568570.html

时间: 2024-11-06 07:25:00

property装饰器函数 @classmethod @staticmethod isinstance和issubclass的相关文章

python staticmethod,classmethod方法的使用和区别以及property装饰器的作用

class Kls(object): def __init__(self, data): self.data = data def printd(self): print(self.data) @staticmethod def smethod(*arg): print('Static:', arg) @classmethod def cmethod(*arg): print('Class:', arg) >>> ik = Kls(23) >>> ik.printd()

property内置装饰器函数和@name.setter、@name.deleter

# property # 内置装饰器函数 只在面向对象中使用 # 装饰后效果:将类的方法伪装成属性 # 被property装饰后的方法,不能带除了self外的任何参数 from math import pi class Circle: def __init__(self, r): self.r = r def perimeter(self): return 2 * pi * self.r def area(self): return pi * self.r**2 * pi c1 = Circle

3.1.8 property装饰器

在类的方法上加上一行@property 装饰器,会使得用户调用该函数属性时,就像调用数据属性一样,不需要加上() 比如想获取一些名词,再加上括号,容易使调用者忘记.动词才加()调用方法. 如下示例: '''BMI指数(bmi是计算而来的,但很明显它听起来像是一个属性而非方法,如果我们将其做成一个属性,更便于理解) 成人的BMI数值: 过轻:低于18.5 正常:18.5-23.9 过重:24-27 肥胖:28-32 非常肥胖, 高于32 体质指数(BMI)=体重(kg)÷身高^2(m) EX:70

@property 装饰器

property() 函数作用于新式类,返回属性值. class C(object): def __init__(self): self._x = None def getx(self): print('get') return self._x def setx(self, value): print('set') self._x = value def delx(self): print('del') del self._x x = property(getx, setx, delx, "I'

面向对象之封装 及@property装饰器使用

目录 封装 1.封装的定义 2.封装的目的: 3.封装的三种方式 4.封装的优点 5.访问限制(封装) @property 装饰器 封装 1.封装的定义 ? 将复杂的丑陋的,隐私的细节隐藏到内部,对外提供简单的使用接口, 对外隐藏内部实现细节,并提供访问的接口; 2.封装的目的: 封装的目的: 面向对象的核心是对象二字,精髓在于整合,封装的目的其实就是把一堆数据属性和方法属性整合到对象中,我们可以把对象比喻成一个容器,其实就是为了把数据存入一个容器中.存的目的就是为了取的,那封装到对象中的好处就

python @property装饰器

@property装饰器 @property装饰器就是负责把一个方法变成属性调用把一个getter方法变成属性,只需要加上@property就可以了,此时,@property本身又创建了另一个装饰器@score.setter,负责把一个setter方法变成属性赋值class Student(object): @property def score(self): return self._score @score.setter def score(self, value): if not isin

面向对象——property装饰器

property装饰器 property装饰器的作用,其实就是将将函数属性伪装成为属性的的装饰器 class People: def __init__(self,name,weight,height): self.name = name self.weight =weight self.height=height @property def bmi(self): return self.weight/(self.height**2) msj = People('msj',82,1.84) pri

Python中,关于@property装饰器

1.为什么使用@property装饰器?br/>在类中,当我么不想在外界直接调用到类的属性,或者不想展示属性的真实内容时,可以用到@property.它规定了我们直接用 对象名.属性名 获取对象属性时并不会直接取得对象的属性,而是通过调用@property装饰过的属性函数来给调用者反馈. 2.我们为什么不使用特定的方法来进行上面的操作?原因是因为太繁琐.例: class Person: def __init__(self, username, password) -> None: self.u

python面向对象:组合、封装、property装饰器、多态

一.组合二.封装三.property装饰器四.多态 一.组合 ''' 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之为组合 2. 为何用组合 组合也是用来解决类与类代码冗余的问题 3. 如何用组合 ''' # class Foo: # aaa=1111 # def __init__(self,x,y): # self.x=x # self.y=y # # def func1(self): # print('Foo内的功能') # # # class Bar: # bbb=2222