2019-03-21

内置类属性

  • 创建类的时候,系统默认为我们添加的类的属性
class Person:
    """说明文档:人类"""
    # 类的字段
    number = 61

    # 对象属性
    def __init__(self, name, age=0, gender='女'):
        self.name = name
        self.age = age
        self.gender = gender

    # ============方法==========
    def object_func(self):
        print('对象方法: '+self.name)

    @classmethod
    def class_func(cls):
        print('类方法: ', cls.number)

    @staticmethod
    def static_func():
        print('静态方法')
    # 系统自带的魔法,可以定制当前类的对象的打印内容。实现这个函数的时候要求有一个字符串类型的返回值
    # 影响单独打印对象的效果
    # def __str__(self):
    #     return str(self.__dict__)[1:-1]

    # 对象作为元素的时候的打印效果
    def __repr__(self):
        return '<'+str(self.__dict__)[1: -1]+'>'

    # def __repr__(self):
    #     return '<%s.%s object at %s>' % (self.__class__.__module__, self.__class__.__name__, hex(id(self)))


p1 = Person('小明', 18, '男')
print(p1)     #'name': '小明', 'age': 18, 'gender': '男'
p2=Person('小花',18)
print([p1,p2])     #[<'name': '小明', 'age': 18, 'gender': '男'>, <'name': '小花', 'age': 18, 'gender': '女'>]
  • _ _ name _ _ 字段
"""
类.__name__   - 获取类的名字
"""
print(Person.__name__,  type(Person.__name__))    # Person <class 'str'>
  • _ _ doc _ _ 字段
"""
类.__doc__     - 获取类的说明文档
"""
print(Person.__doc__)
  • _ _ class _ _ 对象属性
"""
对象.__class__   - 获取对象对应的类(你这个对象是哪个类的对象)
"""
print(p1.__class__)
  • _ _ dict _ _ 字段/对象属性
"""
类.__dict__      -  获取类中所有的字段和对应的值,以字典的形式返回(了解)
对象.__dict__     -  获取对象中所有的属性和对应的值,以字典的形式返回(掌握)
"""
print(Person.__dict__)
print(p1.__dict__)
  • _ _ module _ _ 字段
"""
类.__module__      - 获取指定的类声明在哪个模块中,返回模块名(获取类所在的模块的__name__属性的值)
"""
print(Person.__module__)
  • _ _ bases _ _ 字段
"""
类.__bases__     - 返回当前类的所有父类
"""
print(Person.__bases__)

slots魔法

"""
可以通过给__slots__字段赋值来约束当前类有哪些对象属性;

当在类中给__slots__赋值后,当前类的对象的__dict__属性无效
"""


class Dog:
    __slots__ = ('name', 'age', 'gender', 'name1')

    def __init__(self, name, age=0):
        self.name = name
        self.age = age
        self.gender = '公'


dog = Dog('大黄')


print(dog.__dict__)

私有保护

"""
1、高级语言
在很多的高级面向对象语言中,会将属性和方法分为公开的(在类的外部可以使用)、
私有的(只能在类的内部使用,不能被继承)、受保护(只能在类的内部使用,可以被继承)的三类
2.python
python中类的内容本质上全部都是公开的。私有和公开都只是约定
1)私有化 - a.内容只能在类的内部使用,不能在外面使用。(效果)
          b.在类中的方法名或者属性名前加'__',那么对应的属性和方法就会变成私有的。 (怎么私有化) 
          c.当声明类的时候在名字前加'__',内部会在这个基础前面再加'_类名'。    (私有化的本质)  
        
2)属性保护 - 可通过在对象属性名前加'_',把这个属性标记成收保护类型;为了告诉别人这个属性在使用的时候,
            不要直接用,而是通过getter和setter来使用    
a.getter - 获取对象的属性值之前想要干点儿别的事情,那么就给这个属性添加getter
第一步: 在对应的属性名前加'_'
第二步: 在@property后面声明一个函数,这个函数没有参数,有一个返回值,并且函数名是属性名去掉'_'
第三步: 获取属性值的时候,通过'对象.属性名去掉下划线'去获取属性的值


b.setter - 给属性赋值前干别的事情,就给这个属性添加setter。(想要添加setter必须先有getter)
第一步: 在对应的属性名前加'_'
第二步: 在@getter名.setter后面声明一个函数,这个函数需要一个参数,没有返回值,并且函数名是属性名去掉'_'
第三步: 给属性赋值的时候,通过'对象.属性名去掉下划线=值'的方式赋值  


3.抛出异常: 
a.语法:
raise 异常类型 

b.说明:
raise - 关键字
异常类型  - 可以是系统提供的异常类型,也可以自定义异常类型(必须继承Exception)

4.自定义异常类型:写一个类继承Exception,然后重写__str__方法来自定义错误信息。

"""
class WeekValueError(Exception):
    def __str__(self):
        return '星期的值只能是1-7的整数!'


# raise WeekValueError



# ===============保护==============
class AgeError(Exception):
    def __str__(self):
        return '年龄要求是整数,并且范围在0~150!'


class Person1:
    def __init__(self):
        self._age = 0
        self._week = 6


# 练习: 给age属性添加getter和setter,获取年龄的时候拿到年龄值,和这个年龄对应的阶段;
# 给age赋值的时候,必须是整数,并且范围在0-150。如果不满足要求报错:AgeError
    @property
    def age(self):
        if self._age < 18:
            return self._age, '未成年'
        elif self._age < 30:
            return self._age, '成年'
        elif self._age < 50:
            return self._age, '中年'
        else:
            return self._age, '老年'

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

    @property
    def week(self):
        weeks = ['周1', '周2', '周3', '周4', '周5', '周6', '周日']
        return weeks[self._week - 1]

    @week.setter
    def week(self, x):
        if not isinstance(x, int):
            raise ValueError
        elif not 1 <= x <= 7:
            raise ValueError
        self._week = x


p1 = Person1()


p1.week = 1          # 本质是在调用setter对应的方法
print(p1.week)       # 本质是在调用getter对应的方法

p1.age = 100
age, jieduan = p1.age
print(age, jieduan)

私有化

# ===============私有化==============


class Person:
    __number = 61

    def __init__(self, name, age=18):
        self.name = name
        self.__age = age

    def message(self):
        print(self.__age)

    def __func1(self):
        print(self.name)


p = Person('小明')
print(p.name)
# print(p._Person__age)
p.message()

# print(Person.__number)
# p.__func1()
print(p.__dict__)

什么是继承: 让子类直接拥有父类所有的属性和方法

  • 父类 - 被继承者, 子类 - 继承者
  • python中所有的类都是直接或者间接的继承object

怎么继承

"""
class 子类名(父类1,父类2,...):
    类的内容
"""

子类中添加内容

"""
1)添加字段和方法,直接添加
"""


class Person(object):
    number = 61

    def __init__(self, name, age=0, gender='男'):
        # name = '小花'
        self.name = name
        self.age = age
        self.gender = gender
        self.__num = '0001'

    def fun1(self):
        print('Person对象方法:', self.name)

    @classmethod
    def func2(cls):
        print(cls.number)

    @staticmethod
    def func3():
        print('func3')


class Student(Person):
    flag = '学生!'

    def __init__(self, name):
        # name = '小花'
        # 在子类的方法中去调用父类的方法
        super().__init__(name)     #  super().__init__('小花')
        self.study_id = 'stu001'

    def fun1(self):
        super().fun1()
        print('子类的,func1')

    def study(self):
        print('%s在学习' % self.name)


stu = Student('小花')
print(stu.__dict__)
# 使用父类继承下来的属性和方法
print(Student.number)
print(stu.name)
stu.fun1()
Student.func2()
Student.func3()


# 使用自己的属性和方法
print(Student.flag)
stu.study()


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

推荐阅读更多精彩内容

  • ··· python 1.内置类属性 class Person:"""说明文档:人类"""# 类的字段number...
    曹哥_7d59阅读 182评论 0 0
  • python 关于面对对象 面向对象 关于对面向对象的理解,我认为就是一种资源整合和工具思维。比如说做一件事,不用...
    阳光灿烂的馒头阅读 255评论 0 0
  • 1、设计模式是什么? 你知道哪些设计模式,并简要叙述? 设计模式是一种编码经验,就是用比较成熟的逻辑去处理某一种类...
    方白羽lw阅读 797评论 0 0
  • 块元素和内联元素 块元素: 所谓的块元素就是会独占一行的元素无论它的内容有多少,它都会独占一整行 常见的块元素:d...
    吕若凡阅读 337评论 0 0
  • 奉子成婚,远嫁。婚后与婆婆无休止的争吵,与丈夫无止境的冷战。战争的硝烟逐渐熄灭,筋疲力尽的她最后选择净身出户。 实...
    黄山姑娘阅读 416评论 2 5