我的Python自学之路

python面向对象

2017-02-05  本文已影响37人  MJ爱运动

python有自带的垃圾回收机制,所以不需要定义del方法

定义类的属性

例子

#!/usr/bin/env python

class Programer():
    hobby = 'Do Sports'

    def __init__(self,name,age,weight): #初始化函数
        self.name = name
        self.age = age
        self.__weight = weight #python方式的私有方法,但是只是改了个名字,外部一样可以访问

    def get_weight(self):
        return self.__weight


if __name__ == '__main__':
    programer = Programer('Amao',23,140)
    print(dir(programer))
    print(programer.__dict__)
    print(programer.get_weight())
    print(programer._Programer__weight) #在外部也可以访问私有方法

运行结果:

['_Programer__weight', 'class', 'delattr', 'dict', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'gt', 'hash', 'init', 'le', 'lt', 'module', '_ne
_', 'new', 'reduce', 'reduce_ex', 'repr', 'setattr', 'sizeof', 'str', 'subclasshook', 'weakref', 'age', 'get_weight', 'hobby', 'name']
{'age': 23, '_Programer__weight': 140, 'name': 'Amao'}
140
140

定义类的方法

例子:

#!/usr/bin/env python

class Programer():
    hobby = 'Do Sports'

    def __init__(self,name,age,weight): #初始化函数
        self.name = name
        self._age = age
        self.__weight = weight #python方式的私有方法,但是只是改了个名字,外部一样可以访问

    @classmethod
    def get_hobby(cls):
        return cls.hobby

    @property
    def get_weight(self):
        return self.__weight

    def introduction(self):
        print('My name is %s \nI am %s years old\n' % (self.name,self._age))

if __name__ == '__main__':
    programer = Programer('Amao',23,140)
    print(dir(programer))
    print(Programer.get_hobby()) #类的方法
    print(programer.get_weight) #以属性的形式调用方法
    programer.introduction() #正常调用

运行结果:

['_Programer__weight', 'class', 'delattr', 'dict', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'gt', 'hash', 'init', 'le', 'lt', 'module', '_ne
_', 'new', 'reduce', 'reduce_ex', 'repr', 'setattr', 'sizeof', 'str', 'subclasshook', 'weakref', '_age', 'get_hobby', 'get_weight', 'hobby', 'introduction', 'name']
Do Sports
140
My name is Amao
I am 23 years old

类的继承

#!/usr/bin/env python


class Programer(object):
    hobby = 'Do Sports'

    def __init__(self, name, age, weight):  # 初始化函数
        self.name = name
        self._age = age
        self.__weight = weight  # python方式的私有方法,但是只是改了个名字,外部一样可以访问

    @classmethod
    def get_hobby(cls):
        return cls.hobby

    @property
    def get_weight(self):
        return self.__weight

    def introduction(self):
        print('My name is %s \nI am %s years old\n' % (self.name, self._age))

class BackenProgramer(Programer):


    def __init__(self,name,age,weight,language):
        super(BackenProgramer,self).__init__(name,age,weight)
        self.language = language


if __name__ == '__main__':
    programer = BackenProgramer('Amao', 23, 140,'Python')
    print(dir(programer))
    print(Programer.get_hobby())  # 类的方法
    print(programer.get_weight)  # 以属性的形式调用方法
    programer.introduction()  # 正常调用
    print(programer.__dict__)
    print(type(programer))
    print(isinstance(programer,Programer)) #判断是不是Programer的类,结果为true
    print(issubclass(BackenProgramer,Programer))

运行结果

['_Programer__weight', 'class', 'delattr', 'dict', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'gt', 'hash', 'init', 'le', 'lt', 'module', '_ne
_', 'new', 'reduce', 'reduce_ex', 'repr', 'setattr', 'sizeof', 'str', 'subclasshook', 'weakref', '_age', 'get_hobby', 'get_weight', 'hobby', 'introduction', 'language', 'name']
Do Sports
140
My name is Amao
I am 23 years old
{'language': 'Python', '_age': 23, 'name': 'Amao', '_Programer__weight': 140}
<class 'main.BackenProgramer'> programer对象的类型
True BackenProgramer的实例属于Programer
True BackenProgramer是Programer的子类

python里的magic Method

对象创建和初始化有关的魔术方法

init()

python实例化对象的过程是先通过new方法把属性和对象返回给init()然后再有init()进行实例化

类和运算符

例子:

#!/usr/bin/env python


class Programer(object):
    hobby = 'Do Sports'

    def __init__(self, name, age):  # 初始化函数
        self.name = name
        if isinstance(age, int): #先判断传过来的年龄是不是Int属性如果不是的话就报异常
            self.age = age
        else:
            raise Exception('age must be int')

    def __eq__(self, other):
        if isinstance(other, Programer): # 判断传入进来的对象是不是Programer的对象,不是的话就报异常
            if self.age == other.age:
                return True
            else:
                return False
        else:
            raise Exception('The type of object must be Programer')

    def __add__(self, other):
        if isinstance(other, Programer):
            return self.age + other.age
        else:
            raise Exception('The type of object must be Programer')


if __name__ == '__main__':
    p1 = Programer('amao',25)
    p2 = Programer('shihua',25)
    print(p1==p2)
    print(p1+p2)

运行结果:

True
50

类的展现

例子:

#!/usr/bin/env python


class Programer(object):
    hobby = 'Do Sports'

    def __init__(self, name, age):  # 初始化函数
        self.name = name
        if isinstance(age, int): #先判断传过来的年龄是不是Int属性如果不是的话就报异常
            self.age = age
        else:
            raise Exception('age must be int')

    def __str__(self):
        return "%s is %s years old" % (self.name,self.age)

    def __dir__(self):
        return self.__dict__.keys()


if __name__ == '__main__':
    p1 = Programer('amao',25)
    print(p1)
    print(dir(p1))

运行结果:

amao is 25 years old
['age', 'name'] 只显示在构造函数里定义的属性

未重构strdir的结果:

<main.Programer object at 0x0000000000D5A7F0>
['class', 'delattr', 'dict', 'dir', 'doc', 'eq', 'format', 'ge', 'getattribute', 'gt', 'hash', 'init', 'le', 'lt', 'module', 'ne', 'new', 'redu
ce
', 'reduce_ex', 'repr', 'setattr', 'sizeof', 'str', 'subclasshook', 'weakref', 'age',

类的属性控制

例子:

#!/usr/bin/env python


class Programer(object):
    hobby = 'Do Sports'

    def __init__(self, name, age):  # 初始化函数
        self.name = name
        if isinstance(age, int): #先判断传过来的年龄是不是Int属性如果不是的话就报异常
            self.age = age
        else:
            raise Exception('age must be int')

    def __getattribute__(self, item):
        # return getattr(self,item) # 备注是的两种方法都会引起无限递归
        # return self.__dict__[item]
        return super(Programer,self).__getattribute__(item)

    def __setattr__(self, key, value):
        # setattr(self,key,value) # 这种方式会引起无限递归
        self.__dict__[key] = value
if __name__ == '__main__':
    p1 = Programer('amao',25)
    print(p1.name)
    p1.name = 'shihua'
    print(p1.name)

运行结果

amao
shihua

上一篇下一篇

猜你喜欢

热点阅读