一、类方法和静态方法
1.类方法
a.声明在@classmethod后面的函数就是类方法
b.自带参数cls(cls在函数调用的时候不用传参,系统会自动将调用这个方法的类赋给它)
c.通过类来调用
2.静态方法:
a.声明在@staticmethod后面的函数就是静态方法
b.没有自带的参数
c.通过类来调用
3.三种方法使用场景
对象方法:如果实现函数的功能需要用到对象的属性,那么就把这个函数声明成对象方法
类方法:实现函数的功能不需要用到对象的属性,但需要使用类
静态方法:实现函数的功能不需要用到对象的属性,也不需要类
4.例子:
class Person:
num = 61
# 声明一个类方法
@classmethod
def destroy(cls):
# cls指向的是当前类。调用这个方法的类可以做的事情,cls都能做
print('cls:',cls, cls.num)
p2 = cls()
print(p2)
print('人类破坏环境')
# 声明一个静态方法
@staticmethod
def func1():
print(Person.num)
p3 = Person()
print(p3)
print('人类的静态方法')
二、私有化
1.定义:
定义:将类的内容在类的外面隐藏
方法:在类中方法名或者属性名前加两个下划线(不能以两个下划线结束)
作用:私有的方法和属性只能在类的内部使用,不能在类的外部使用
例子:
class Person:
# 私有字段
__num = 61
def __init__(self, name, age):
self.name = name
# 私有对象属性
self.__age = age
def show_info(self):
print(self.__age)
self.__func1()
# 私有的对象方法
def __func1(self):
print('私有对象方法')
p1 = Person('小明', 23)
print(p1.name)
p1.show_info()
2.私有的原理
注意:python中没有真正的私有化(没有从访问权限上去限制内容的访问)
私有的原理就是在私有的属性名或者方法名前加前缀'_类名'来阻止外部直接通过带两个下划线的名字去使用属性和方法
三、setter和getter
1.getter和setter的作用
如果希望在通过对象.属性获取属性的值之前,再干点儿别的事情,就可以给这个属性添加getter。
如果希望在通过对象.属性给属性赋值之前,再干点儿别的事情,就可以给这个属性添加setter
2.添加getter
方法:
a.在属性名前加_
b.添加属性对应的getter字面量
@property
def 属性名去掉_(self):
函数体 --> 会对属性的值进行处理后,返回相应的结果(必须要有返回值)
3.添加setter
如果想要添加setter必须要先添加getter
方法:
a.@getter名.setter字面量
def 属性名去掉_(self, 参数):
做别的事情
self.属性名 = 处理后的值
4.例子
class Number:
def __init__(self):
self._value = 0
# 0-6保存
self._week = 3
self.type = int
self.id = None
# _value添加getter和setter
@property
def value(self):
return self._value
@value.setter
def value(self, x):
if not -100 <= x <= 100:
raise ValueError
self._value = x
# _week的getter
@property
def week(self):
if self._week == 0:
return '星期天'
elif self._week == 1:
return '星期一'
elif self._week == 2:
return '星期二'
elif self._week == 3:
return '星期三'
elif self._week == 4:
return '星期四'
elif self._week == 5:
return '星期五'
elif self._week == 6:
return '星期六'
"""
isinstance(值, 类) --> 判断指定的值是否是指定类型(返回值是bool)
"""
@week.setter
def week(self, value):
# 如果传的值不是整型数据
if not isinstance(value, int):
raise ValueError
if not 0 <= value <= 6:
raise ValueError
self._week = value
number = Number()
number.value = 99
print(number.week) # number.week 实质是在通过number去调用getter对应的week方法
number.week = 1 # number.week = 值 实质是通过number去调用setter对应的week方法
number.value = 100
print(number.value)
作业
1.定义一个学生类。有属性:姓名、年龄、成绩(语文,数学,英语)[每课成绩的类型为整数]
方法: a. 获取学生的姓名:getname() b. 获取学生的年龄:getage(),c. 返回3门科目中最高的分数。get_course()
class StuCourse:
def __init__(self,name,age,*scores):
self.name =name
self.age = age
self.scores =scores
def top_score(self):
return max(self.scores)
stu1 = StuCourse('张三',18,89,96,75)
print(getattr(stu1,'name'))
print(getattr(stu1,'age'))
print(stu1.top_score())
2.建立一个汽车类Auto,包括轮胎个数,汽车颜色,车身重量,速度等成员变量,并通过不同的构造方法创建实例。至少要求 汽车能够加速 减速 停车。 再定义一个小汽车类CarAuto 继承Auto 并添加空调、CD等成员变量 覆盖加速 减速的方法
class Auto:
def __init__(self,tyre_number,color,weight,speed):
self.tyre_number = tyre_number
self.color = color
self.weight =weight
self.speed = speed
def speed_up(self):
self.speed += 2
def speed_cut(self):
self.speed -= 2
def stop(self):
self.speed = 0
class CarAuto(Auto):
def __init__(self,tyre_number,color,weight,speed,air_conditioner,CD):
super().__init__(tyre_number,color,weight,speed)
self.air_conditioner = air_conditioner
self.CD = CD
def speed_up(self):
pass
def speed_cut(self):
pass
car1 = CarAuto(4,'yellow',1000,10,'on','that girl')
print(car1.speed,car1.air_conditioner)
3.创建一个名为User 的类,其中包含属性firstname 和lastname ,还有用户简介通常会存储的其他几个属性。在类User 中定义一个名 为describeuser() 的方法,它打印用户信息摘要;再定义一个名为greetuser() 的方法,它向用户发出个性化的问候。
import random
class User:
def __init__(self,first_name,last_name,age = 18, tel= 1234567):
self.first_name = first_name
self.last_name = last_name
self.age = age
self.tel = tel
def describe_user(self):
print(str(self.__dict__)[1:-1])
def greet_user(self):
print('hello,%s' % (self.first_name+self.last_name))
class Admin(User):
def __init__(self,first_name,last_name,age = 18, tel= 1234567):
super().__init__(first_name,last_name)
self.privileges = ['can add post','can delete post', 'can ban user']
def show_privileges(self):
n =random.randint(0,2)
print(self.privileges[n])
admin = Admin('王','磊')
admin.describe_user()
admin.greet_user()
admin.show_privileges()
4.创建一个Person类,添加一个类字段用来统计Perosn类的对象的个数
class Person:
number = 0
def __init__(self):
Person.number += 1
person1 =Person()
person2 =Person()
print(Person.number)