python面向对象中

一、类属性

类中的属性:对象属性、类属性(类的字段)

1.类属性

直接定义在类中的变量就是类属性
类属性的值不会因为对象不同而不一样

2.对象属性

通过 self.属性名 = 值 定义在init函数中的属性
对象属性的值会因为对象不同而不一样

class Person:
    num = 61
    x = 100


print(Person.num)
Person.num = 60

二、对象属性的增删改查

class Student:
    def __init__(self, name, age=0, gender='男', score=0):
        self.name = name
        self.age = age
        self.gender = gender
        self.score = score

    def __repr__(self):
        return f'<{str(self.__dict__)[1:-1]}>'


stu1 = Student('小明')
stu2 = Student('小花', gender='女')

1.查(获取属性的值)

对象.属性 - 获取对象指定属性对应的值;属性不存在会报错
getattr(对象, 属性名) - 获取对象指定属性对应的值;属性不存在会报错
getattr(对象, 属性名, 默认值) - 获取对象指定属性对应的值; 属性不存在不会报错,并且返回默认值

print(stu1.name)
# print(stu1.name1)   # AttributeError: 'Student' object has no attribute 'name1'

print(getattr(stu1, 'name'))    # 小明
print(getattr(stu1, 'age'))     # 0
# print(getattr(stu1, 'name1'))   # AttributeError: 'Student' object has no attribute 'name1'

print(getattr(stu1, 'name', '无名氏'))    # 小明
print(getattr(stu1, 'name1', '无名氏'))   # 无名氏

# 根据输入的内容获取对象属性的值
# name  -> 小明
# age  -> 0
# value = input('请选择(name,age,gender,score):')
# print(getattr(stu1, value))

2.改、增

对象.属性 = 值 - 当属性不存在就给对象添加属性,属性存在的时候就修改指定属性的值
setattr(对象, 属性名, 值) - 当属性不存在就给对象添加属性,属性存在的时候就修改指定属性的值

# 属性存在是修改
stu1.name = 'xiaoming'
print(stu1)

stu1.height = 180
print(stu1)    # <'name': 'xiaoming', 'age': 0, 'gender': '男', 'score': 0, 'height': 180>
print(stu1.height)

setattr(stu1, 'age', 18)
print(stu1)    # <'name': 'xiaoming', 'age': 18, 'gender': '男', 'score': 0, 'height': 180>

setattr(stu1, 'weight', 80)
print(stu1)   # <'name': 'xiaoming', 'age': 18, 'gender': '男', 'score': 0, 'height': 180, 'weight': 80>

print(stu2)   # <'name': '小花', 'age': 0, 'gender': '女', 'score': 0>

3.删

del 对象.属性 - 删除对象中指定的属性
delattr(对象, 属性名) - 删除对象中指定的属性

del stu2.age    # <'name': '小花', 'gender': '女', 'score': 0>
print(stu2)

delattr(stu2, 'gender')
print(stu2)     # <'name': '小花', 'score': 0>

三、内置属性

# python在定义类的时候系统自动添加的属性(从基类中继承下来的属性)就是内置属性
class Student:
    def __init__(self, name, age=18, score=0):
        self.name = name
        self.age = age
        self.score = score


class Dog:
    # 类属性
    num = 100

    # 对象属性
    def __init__(self, name, age=1, color='白色'):
        self.name = name
        self.age = age
        self.color = color

    # 方法
    def eat(self, food):
        print(f'{self.name}在吃{food}')

    @classmethod
    def show_num(cls):
        print(f'狗的数量:{cls.num}')

    @staticmethod
    def bark():
        print('狗嗷嗷叫~')

    def __repr__(self):
        c = self.__class__
        m = c.__module__
        return f'<{m}模块.{c.__name__}类的对象: name={self.name},age={self.age},color={self.color}>'


dog1 = Dog('大黄')

1. module

类属性;
类.module - 获取定义的模块的模块名

print(Dog.__module__)
print(int.__module__)

2.class

对象.class - 获取对象对应的类

c = dog1.__class__
print(c)
print(type(dog1))
print(Dog)

3.name

类.name - 获取类名

print(Dog.__name__)    # 'Dog'

# 重写 repr 方法, 要求以: <xxx模块.xxx类的对象: 属性1=值1,属性2=值2>

4.dict

类.dict - 将类转换成字典(类的类属性名作为key,类属性的值作为值)
对象.dict - 将对象转换成字典(对象属性名作为key,属性的值作为值)

print(Dog.__dict__)
print(dog1.__dict__)

5. doc

类.doc - 获取类的说明文档

print(list.__doc__)

6.basebases

类.base - 获取当前类的父类
类.bases - 获取当前类所有的父类

print(Dog.__base__)    # <class 'object'>
print(Dog.__bases__)   # (<class 'object'>,)

7. slots

class Person:

    # __slots__可以约束当前类的对象能够拥有哪些对象属性
    __slots__ = ('name', 'age', 'height')

    def __init__(self, name, age=10):
        self.name = name
        self.age = age


p1 = Person('小明')
# p1.name1 = 'xiaoming'
p1.height = 180

# 注意: 如果给类属性__slots__赋值了,那么这个类的对象不能再使用__dict__属性
# print(p1.__dict__)

六、私有化

1.访问权限(针对属性和方法)

公开的:在类的内部和外部都可以使用,也能被继承
保护的:在类的内部可以使用,类的外部不能使用,可以被继承
私有的:只能在类的内部使用,不能被继承

严格来说,python中所有的属性和方法都是公开的,这儿说的私有化其实是假的私有化

class Person:
    num = 100
    __num2 = 61

    def __init__(self):
        self.name = '小明'
        self.age = 10
        self.__gender = '男'

    def eat(self):
        print(f'{self.name}在吃饭')
        print(self.__gender)


p1 = Person()

print(Person.num)
print(p1.name, p1.age)
p1.eat()

# print(p1.__gender)
# print(Person.__num2)

私有化的原理:

print(p1.__dict__)     # {'name': '小明', 'age': 10, '_Person__gender': '男'}
print(p1._Person__gender)

七、getter和setter

1.getter和setter的作用

getter作用:在获取某个属性值之前想要做别的事情,就给这个属性添加getter
setter作用:在给属性赋值之前想要做别的事情,就给这个属性添加setter

2.怎么添加getter和setter

1)getter
第一步:在需要添加getter的属性名前加_
第二步:定义getter对应的函数(1.需要@property装饰器 2.函数名就是不带的属性名 3.函数需要一个返回值)
第三步:获取属性值的通过: 对象.不带
属性名 (本质就是在调用getter对应的函数,取到属性值就是函数的返回值)

2)setter
如果想要给属性添加setter必须先给属性添加getter
第一步:添加getter
第二步:定义setter对应的函数 (1.需要 @getter函数名.setter 装饰器 2.函数名就是不带的属性名 3.需要一个参数不需要返回值,这个参数就是尝试给属性赋的值)
第三步:给属性赋值:对象.不带
属性名 = 值 (本质就是在调用setter对应的函数)

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

    @property
    def area(self):
        print('area属性值被获取')
        self._area = self.width * self.length
        return self._area

    @area.setter
    def area(self, value):
        # print(f'value:{value}')
        # self._area = value
        raise ValueError


r1 = Rect(4, 5)
print('==========')
print(r1.area)
print('++++++++')

# 不能让矩形直接修改面积属性值
# r1.area = 100
# print(r1.__dict__)

#
r1.width = 10
print(r1.area)

r1.length = 10
print(r1.area)

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