day15-类和对象

一、类方法和静态方法

类中方法:对象方法、类方法和静态方法。

1.对象方法:

a.直接声明在类中
b.自带参数self
c.通过对象来调用

2.类方法:

a.声明在@classmethod后面的函数就是类方法
b.自带参数cls(cls在函数调用的时候不用传参,系统会自动将调用这个方法的类赋给它)
c.通过类来调用

3.静态方法:

a.声明在@staticmethod后面的函数就是静态方法
b.没有自带参数
c.通过类来调用

4.怎么选择使用哪种方法(重点!):

对象方法:如果实现函数的功能需要用到对象的属性,那么就把这个函数声明成对象方法。

静态方法和类方法:实现函数的功能不需要用到对象的属性,就可以选择用静态方法或者类方法。

类方法:在不使用对象属性的前提下,需要使用类。

静态方法:既不需要使用对象的属性也不需要使用类。

代码

class Math:
    pi = 3.1415926

    @classmethod
    def circle_area(cls, radius):
        return cls.pi * radius

    @staticmethod
    def sum(num1, num2):
        return num1 + num2


print(Math.circle_area(3))
print(Math.circle_area(4))

print(Math.sum(3, 5))


class Rect:
    def __init__(self, length, width):
        self.length = length
        self.width = width

    def area(self):
        return self.length * self.width


class Person:
    num = 61

    # 声明一个类方法
    @classmethod
    def destory(cls):
        # cls指向的是当前类,调用这个方法的类可以做的事情,cls都能做
        print('cls:',cls, cls.num)
        p2 = cls()
        print('人类破坏环境')

    # 声明一个静态方法
    @staticmethod
    def func1():
        print(Person.num)
        p3 = Person()
        print('人类的静态方法')

print(Person)
print(Person.num)
Person.destory()

测试结果

1.PNG

二、私有化

类中的内容默认都是公开的(在类的外面可以使用)。

1.私有化 --> 将类的内容在类的外面隐藏

在类中的方法名或者属性名前加两个下划线(不能以两个下划线结束)

私有的方法和属性只能在类的内部使用,不能在类的外部使用。

2.私有化的原理

python中没有真正的私有化(没有从访问权限上去限制内容的访问)

私有的原理就是在私有的属性名或者方法名前加前缀'_类名'来阻止外部直接通过带两个下划线的名字去使用属性和方法。

代码

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)
# print(p1.age)
p1.show_info()

# p1.func1()

# print(Person.num)

print(p1.__dict__)
print(p1._Person__age)

测试结果

1.PNG

三、getter和setter

1.什么时候需要添加对象属性的getter和setter

如果希望在通过对象.属性获取属性的值之前,再干点别的事情,就可以给这个属性添加getter。

如果希望在通过对象.属性给属性赋值之前,再干点别的事情,就可以给这个属性添加setter。

2.怎么添加setter和getter

getter:
a.在属性名前加_
b.添加属性对应的getter
@property
def 属性名去掉(self):
函数体 --> 对属性的值进行处理后,返回相应的结果(必须要有返回值)
c.使用属性的值的时候,不通过带下划线的属性名去使用,而是通过没有下划线的属性名去使用
注意:对象.不带下划线的属性 --> 调用getter对应的函数。
setter:
如果想要添加setter必须要先添加getter
a.添加setter
@getter名.setter
def 属性名去掉
(self, 参数):
做别的事情
self.属性名 = 处理后的值

代码

class Number:
    def __init__(self):
        self._value = 0
        # 0-6保存
        self._week = 1
        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 = 100
print(number._week)
print(number.week)  # number.week 实质是在通过number去调用getter对应的week方法

number.week = 1  # number.week = 值 实质是通过number去调用setter对应的week方法

number.value = 100
print(number.value)

测试结果

1.PNG

练习:要求age的值只能在0-150之间,超过范围报错;获取age的值的时候返回年龄值,并且返回这个年龄对应的阶段。

代码

class Person:
    def __init__(self, name):
        self.name = name
        self._age = None

    @property
    def age(self):
        if self._age < 18:
            return self._age, '未成年'
        else:
            return self._age, '成年人'

    @age.setter
    def age(self, value):
        if not 0 < value < 150:
            raise ValueError
        self._age = value


p1 = Person('Mike')
p1.age = 18

age, stage = p1.age
print('age:', age, ' stage:', stage)

测试结果

2.PNG

四、作业

1.定义一个学生类。

有属性:姓名、年龄、成绩(语文,数学,英语)[每课成绩的类型为整数]
方法: a. 获取学生的姓名:getname() b. 获取学生的年龄:getage() c. 返回3门科目中最高的分数。get_course()

代码

class Student:
    scores = {}

    def __init__(self, name):
        self.name = name
        self._age = None
        self._score1 = None
        self._score2 = None
        self._score3 = None


    @property
    def age(self):
        return self._age

    @age.setter
    def age(self, value):
        if not isinstance(value, int):
            raise ValueError
        if not 0 < value < 150:
            raise ValueError
        self._age = value

    @property
    def score1(self):
        return self._score1

    @score1.setter
    def score1(self, value1):
        if not isinstance(value1, int):
            raise ValueError
        if not 0 <= value1 <= 100:
            raise ValueError
        self._score1 = value1

    @property
    def score2(self):
        return self._score2

    @score2.setter
    def score2(self, value2):
        if not isinstance(value2, int):
            raise ValueError
        if not 0 <= value2 <= 100:
            raise ValueError
        self._score2 = value2

    @property
    def score3(self):
        return self._score3

    @score3.setter
    def score3(self, value3):
        if not isinstance(value3, int):
            raise ValueError
        if not 0 <= value3 <= 100:
            raise ValueError
        self._score3 = value3

    def add_scores(self, score1, score2, score3):
        self.score1 = score1
        self.score2 = score2
        self.score3 = score3
        Student.scores = {'语文': self.score1, '数学': self.score2, '英语': self.score3}

    def getname(self):
        return self.name

    def getage(self):
        return self.age

    @classmethod
    def get_course(cls):
        max1 = 0
        max_score = 0
        for score in cls.scores:
            if cls.scores[score] > max1:
                max1 = cls.scores[score]
                max_score = cls.scores[score]
        return max_score


stu1 = Student('Mike')

stu1.age = 20

stu1.add_scores(95, 98, 86)

# 获取学生的姓名
name = stu1.getname()
print('name:'+name)

# 获取学生的年龄
age = stu1.getage()
print('age:', age)

# 获取3门科目中最高的分数
max_score = stu1.get_course()
print('max_score:', max_score)

测试结果

1.PNG

2.创建一个Person类,添加一个类字段用来统计Perosn类的对象的个数。

代码

class Person:
    count = 0

    def __init__(self):
        Person.count += 1


p1 = Person()
p2 = Person()
p3 = Person()
p4 = Person()
p5 = Person()
p6 = Person()
count = Person.count
print('count:', count)

测试结果

2

3.要求age的值只能在0-150之间,超过范围报错;获取age的值的时候返回年龄值,并且返回这个年龄对应的阶段。

代码

class Person:
    def __init__(self, name):
        self.name = name
        self._age = None

    @property
    def age(self):
        if self._age < 18:
            return self._age, '未成年'
        else:
            return self._age, '成年人'

    @age.setter
    def age(self, value):
        if not 0 < value < 150:
            raise ValueError
        self._age = value


p1 = Person('Mike')
p1.age = 18

age, stage = p1.age
print('age:', age, ' stage:', stage)

测试结果

3.PNG

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,192评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,858评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,517评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,148评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,162评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,905评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,537评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,439评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,956评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,083评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,218评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,899评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,565评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,093评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,201评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,539评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,215评论 2 358

推荐阅读更多精彩内容

  • 想好再写
    辛格道格尔阅读 347评论 0 0
  • 好多天以前 我为你准备了一些眼泪 想在你离开的时候送给你 你怕我想念吗 竟办一些令人费解的事 还亲口说无所谓 就像...
    野地百合花阅读 332评论 1 6
  • 2017年5月17日星期三晴 早晨起来看看种的花生出来了没有,到了地里一看,花生出来了很多,有大的.小的。还有没出...
    江钰珂妈妈阅读 254评论 0 0