python类学习:动态添加类的属性和方法、@property装饰器、运算符重载

动态添加类的属性和方法

# -*- coding: utf-8 -*- #
# File Name:        动态添加属性.py
# Author:           波澜不惊
# CreatedTime:      2022/1/13 10:38
# Description:      功能描述      
# @Software:        PyCharm


# 创建一个空类
from types import MethodType


class Person(object):
    pass


per = Person()
# 动态添加属性,这体现了动态语言的特点(灵活)
per.name = "tom"
print(per.name)


# 动态添加方法
def say(self):
    print("my name is " + self.name)


per.speak = MethodType(say, per)
per.speak()
'''
per.speak = say  方法二,略微简陋
per.speak(per)
'''


# 思考: 如果我们想要限制实例的属性怎么办?
# 比如: 只允许给对象添加name、age、height、weight属性
# 创建一个空类
class Kong(object):
    __slots__ = ("name", "age", "speak")


kong = Kong()
kong.name = "吃"
# kong.hight = 178
# AttributeError: 'Kong' object has no attribute 'height'
---执行结果-------------------------------------------------------
tom
my name is tom

进程已结束,退出代码为 0

@property装饰器

# !/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2022/1/16 19:41
# @Author  : 波澜不惊
# @File    : @property.py
# property可以让你对受限制访问的属性使用点语法

class Person(object):
    def __init__(self, age):
        # 属性直接对外暴露
        # self.age = age
        # __age限制对象属性访问
        # 需要借助自己写的set和get方法访问属性
        self.__age = age
    '''
    def setAge(self, age):
        if age > 0:
            self.__age = age
        else:
            self.__age = 0

    def getAge(self):
        return self.__age
    '''
    # 方法名为受限制的变量去掉双下划线
    @property
    def age(self):
        return self.__age

    @age.setter     # 去掉下划线.setter
    def age(self, age):
        if age > 0:
            self.__age = age
        else:
            self.__age = 0


per = Person(18)
per.age = -13
print(per.age)

# 属性直接对外暴露
# 不安全,没有数据的过滤
# per.age = -10
# print(per.__age)

# per.setAge(15)
# print(per.getAge())
---执行结果----------------------------------------
0

进程已结束,退出代码为 0

运算符重载

# !/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2022/1/16 20:13
# @Author  : 波澜不惊
# @File    : 运算符重载.py
#

print(1 + 2)
print("1" + "2")


class Person (object):
    def __init__(self, num):
        self.num = num

    # 运算符重载
    def __add__(self, other):
        return Person(self.num + other.num)

    def __str__(self):
        return "num = " + str(self.num)


per1 = Person(1)
per2 = Person(1)
print(per1 + per2)  # per1.__add__(per2)
print(per1)
print(per2)
---执行结果-----------------------------------------------
3
12
num = 2
num = 1
num = 1

进程已结束,退出代码为 0

练习

  • 动态给类添加方法,具体是对猫的类中没有设置奔跑的方法,在类外添加这个方法,并打印显示
# !/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2022/1/16 21:01
# @Author  : 波澜不惊
# @File    : 题1.py
# 动态给类添加方法,具体是对猫的类中没有设置奔跑的方法,
# 在类外添加这个方法,并是打印显示
from types import MethodType


class Cat(object):
    def __init__(self, name):
        self.name = name


def run(self):
    print(self.name + "在奔跑")


tom = Cat("Tom")
tom.run = MethodType(run, tom)
tom.run()
---执行结果-------------------------------------
Tom在奔跑

进程已结束,退出代码为 0
  • 在类中对__pow__、__cmp__进行运算符重载,主要对的两个成绩进行平方运算、比较两个成绩
# !/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2022/1/16 21:02
# @Author  : 波澜不惊
# @File    : 题2.py
# 在类中对__pow__、__cmp__进行运算符重载,主要对的两个成
# 绩进行平方运算、比较两个成绩
import operator


class Score(object):
    def __init__(self, name, num):
        self.name = name
        self.num = num

    def __pow__(self, power, modulo=None):
        return Score(self.name, pow(self.num, power))

    def __lt__(self, other):
        if self.num > other.num:
            return self.name + "的成绩更高"
        else:
            return other.name + "的成绩更高"

    def __str__(self):
        return self.name + "的成绩是" + str(self.num)


sco1 = Score("张三", 59)
sco2 = Score("老罗", 61)

print(pow(sco1, 2))
print(operator.lt(sco1, sco2))
---执行结果-------------------------------------
张三的成绩是3481
老罗的成绩更高

进程已结束,退出代码为 0
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值