一. property的用法,将一个函数伪装成属性
#第一种写法:
from math import pi
class Circle:
def __init__(self,r):
self.r=r
def mj(self):
return pi*self.r**2
def zc(self):
return 2*pi*self.r
c1=Circle(3)
print(c1.mj())
#第二种写法:用property 将一个函数伪装成为属性
class Circle:
def __init__(self,r):
self.r=r
@property
def mj(self):
return pi*self.r**2
@property
def zc(self):
return 2*pi*self.r
c1=Circle(3)
print(c1.mj)
# property 跟__私有属性的结合 如:苹果打折的问题
class Goods():
def __init__(self,price,discount):
self.__price=price
self.discount=discount
@property
def price(self): #现有的价格
return self.__price * self.discount
@price.setter #设置一个新的属性即新的价格
def price(self,newprice):
self.__price=newprice
@price.deleter #删除一个价格
def price(self):
del self.__price
apple=Goods(8,0.7)
print(apple.price)
apple.price=10
print(apple.price)
print(apple.__dict__)
del apple.price
print(apple.__dict__)
二.classmethod
类方法通过@classmethod装饰器实现,类方法和普通方法的区别是, 类方法只能访问类变量,不能访问实例变量
如果某一个类中的方法 并没有用到这个类的实例中的具体属性
只是用到了类中的静态变量 就使用类方法
class Dog(object):
def __init__(self,name):
self.name = name
@classmethod
def eat(self):
print("%s is eating" % self.name)
d = Dog("ChenRonghua")
d.eat()
执行报错如下,说Dog没有name属性,因为name是个实例变量,类方法是不能访问实例变量的
此时可以定义一个类变量,也叫name,看下执行效果
class Dog(object):
name = "我是类变量"
def __init__(self,name):
self.name = name
@classmethod
def eat(self):
print("%s is eating" % self.name)
d = Dog("ChenRonghua")
d.eat()
这次没报错
# classmethod
class Person:
Country='中国人'
@classmethod #把func变成了一个类方法
def func(cls): #cls指向了类的内存空间
print('当前角色的国家是%s' %cls.Country)
# alex=Person()
# alex.func()
Person.func()
三.staticmethod 静态方法不需要self这个参数了
通过@staticmethod装饰器即可把其装饰的方法变为一个静态方法,什么是静态方法呢?
其实不难理解,普通的方法,可以在实例化后直接调用,并且在方法里可以通过self.调用实例变量或类变量,但静态方法是不可以访问实例变量或类变量的,一个不能访问实例变量和类变量的方法,其实相当于跟类本身已经没什么关系了,它与类唯一的关联就是需要通过类名来调用这个方法
# staticmethod
## 如果 一个方法 既不会用到对象中的属性也不会用到类中的属性
# 就应该被定义为一个静态方法
# 小编创建了一个Python学习交流群:725638078
class Student:
@staticmethod #不需要实例化一个学生可以直接调用login登录方法
def login():
name=input('name:')
pwd=input('pwd:')
if name =='hu' and pwd =='123':
print('登录成功')
Student.login()