zoukankan      html  css  js  c++  java
  • 类与反射

    本节目录
    1、抽象接口
    2、静态方法、类方法、属性方法
    3、类的特殊方法
      3.1 __doc__  表示类的描述信息(注释)
      3.2 __module__ 和 __class__
      3.3 __init__ 构造方法,通过类创建对象时,自动触发执行。
      3.4 __del__
      3.5 __call__ 对象后面加括号,触发执行
      3.6 __dict__ 查看类或对象中的所有成员
      3.7 __str__
      3.8 __getitem__、__setitem__、__delitem__
      3.9 __new__ __metaclass__
    4、异常处理
      4.1 基本结构
      4.2 完整结构
      4.3 断言
      4.4 自定义异常
    5、反射
     

    1、抽象接口
    py2写法:
    import abc
    class Alert(object):
    '''报警基类'''
    __metaclass__ = abc.ABCMeta #必须实现子类实例化和调用send必须重写send,否则报错
    @abc.abstractmethod
    def send(self):
    '''报警消息发送接口'''
    pass
    class MailAlert(Alert):
    pass
    m = MailAlert()
    m.send()
    py3写法:
    不重写则报错
    class Alert(object):
    '''报警基类'''
    def send(self):
    '''报警消息发送接口'''
    raise NotImplementedError

    class MailAlert(Alert):
    pass

    m = MailAlert()
    m.send()
    报错:
    F:PythonPython3python.exe D:/python培训/our_python/day8/抽象接口.py
    Traceback (most recent call last):
    File "D:/python培训/our_python/day8/抽象接口.py", line 12, in <module>
    m.send()
    File "D:/python培训/our_python/day8/抽象接口.py", line 6, in send
    raise NotImplementedError
    NotImplementedError
    正确写法:
    class Alert(object):
    '''报警基类'''
    def send(self):
    '''报警消息发送接口'''
    raise NotImplementedError

    class MailAlert(Alert):
    def send(self,msg):
    print("__send__", msg)

    m = MailAlert()
    m.send("sssss")
    输出:__send__ sssss

    2、静态方法、类方法、属性方法
    #静态方法即不能访问公有属性也不能访问实例
    #类方法只能访问公有属性,不能访问实例
    #属性方法,把一个方法编程一个静态属性,直接访问这个方法、但不能调用这个方法
    测试:
    class Person(object):
    name = "class_jack"
    def __init__(self,name):
    self.name = name

    @staticmethod #静态方法即不能访问公有属性也不能访问实例
    def eat(name,food):
    print("%s is eating..%s" % (name,food))
    @classmethod #类方法只能访问公有属性,不能访问实例
    def walk(self):
    print("%s is walking..." % self.name)
    @property #属性方法,把一个方法编程一个静态属性
    def talk(self):
    print("%s says "% self.name)
    @talk.setter #修改属性
    def talk(self,C_name):
    self.name = C_name
    print("%s says " % self.name)

    @talk.deleter
    def talk(self):
    print("del %s says " % self.name)

    p = Person("jack")

    p.eat("xiaoming","noodle") #静态方法,传入自己的变量
    p.walk() #直接访问类变量
    p.talk #直接访问,但不能使用p.talk ()调用
    p.talk = "TTT" #修改属性
    del p.talk #删除属性


    属性方法应用--航班查询
    class Flight(object):
    def __init__(self,name):
    self.flight_name = name


    def checking_status(self):
    print("checking flight %s status " % self.flight_name)
    return 1

    @property
    def flight_status(self): ##属性方法,把一个方法编程一个静态属性,只能访问
    status = self.checking_status()
    if status == 0 :
    print("flight got canceled...")
    elif status == 1 :
    print("flight is arrived...")
    elif status == 2:
    print("flight has departured already...")
    else:
    print("cannot confirm the flight status...,please check later")

    @flight_status.setter # 修改属性
    def flight_status(self, status):
    status_dic = {
    0: "canceled",
    1: "arrived",
    2: "departured"
    }
    print("33[31;1mHas changed the flight status to 33[0m", status_dic.get(status))

    @flight_status.deleter # 删除属性
    def flight_status(self):
    print("status got removed...")

    f = Flight("CA980")
    f.flight_status
    f.flight_status = 2 #触发@flight_status.setter
    f.flight_status
    del f.flight_status #触发@flight_status.deleter
    f.flight_status

    3、类的特殊方法
    3.1 __doc__  表示类的描述信息(注释)
    print(f.__doc__)

    3.2 __module__ 和 __class__
    __module__ 表示当前操作的对象在那个模块
    __class__ 表示当前操作的对象的类是什么
    print(f.__module__)
    __main__
    print(f.__class__)
    <class '__main__.Flight'>

    3.3 __init__ 构造方法,通过类创建对象时,自动触发执行。
    3.4 __del__
    3.5 __call__ 对象后面加括号,触发执行
    def __call__(self, *args, **kwargs):
    print("__call:",args,kwargs)
    输出:
    __call: ('sssss',) {}

    3.6 __dict__ 查看类或对象中的所有成员
    print(f.__dict__)
    输出:{'flight_name': 'CA980'}

    3.7 __str__
    如果一个类中定义了__str__方法,那么在打印 对象 时,默认输出该方法的返回值
    def __str__(self):
    return "<flight:%s,status:%s>" %(self.flight_name,self.flight_status)
    输出:
    <flight:CA980,status:None>

    3.8 __getitem__、__setitem__、__delitem__
    def __getitem__(self, key):
    print('__getitem__', key)

    def __setitem__(self, key, value):
    print('__setitem__', key, value)

    def __delitem__(self, key):
    print('__delitem__', key)

    st = f['CA980'] #触发__getitem__
    f['CA980'] = 1 #触发__setitem__
    del f['CA980'] #触发__delitem__
    输出:
    __getitem__ CA980
    __setitem__ CA980 1
    __delitem__ CA980

    3.9 __new__ __metaclass__
    其他资料:https://zhuanlan.zhihu.com/p/23887627
    class Foo(object):
    def __init__(self,name):
    self.name = name
    f = Foo("alex")
    print type(f) # 输出:<class '__main__.Foo'> 表示,obj 对象由Foo类创建
    print type(Foo) # 输出:<type 'type'> 表示,Foo类对象由 type 类创建

    自建一个类(动态创建类):
    def talk(self,msg):
    print("%s is talking: %s" % (self.name,msg))
    def __init__(self,name):
    self.name = name
    Dog = type("Dog",(object,),{"talk":talk,"__init__":__init__})

    print(Dog)
    print(type(Dog))
    d = Dog("xiaoming")
    print(type(d))
    d.talk("wwwwww")

    输出:
    <class '__main__.Dog'>
    <class 'type'>
    <class '__main__.Dog'>
    xiaoming is talking: wwwwww


    4、异常处理
    4.1 基本结构
    while True:
    try:
    print("1212")
    except Exception as e:
    print("Error")
    4.2 完整结构
    while True:
    try:
    print("1212")
    except Exception as e:
    print("Error")
    else:
    print("3434")
    finally:
    print("5656")

    4.3 断言
    assert 条件
    条件为True则继续,否则主动抛出异常


    4.4 自定义异常
    class TTTError(Exception):
    def __init__(self,message):
    self.msg = message
    super(TTTError,self).__init__(message)

    try:
    name = "Alex"
    if name != "TTT":
    raise TTTError("你不是TTT") #主动抛出错误
    except TTTError as e:
    print("TTTError",e)
    except Exception as e:
    print(e,111111)

    输出:
    TTTError 你不是TTT

    5、反射

    cat account
    def login():
    return "请输入用户名、密码"
    def logout():
    return "跳转到登录界面"

    from controller import account
    while True:
    action = input(">>:")
    if (hasattr(account,action)):
    func = getattr(account,action)
    result = func()
    else:
    result = '404'
    print(result)
    输出:
    F:PythonPython3python.exe D:/python培训/our_python/day8/app.py
    >>:login
    请输入用户名、密码
    >>:logout
    跳转到登录界面
    >>:asd
    404

  • 相关阅读:
    7月30日 举办专注于微服务的.NET Conf Focus
    我和ABP vNext 的故事
    Windows环境搞好的Dockerfile文件 在Linux上报错了
    [LeetCode] 955. Delete Columns to Make Sorted II 删除列使其有序之二
    [LeetCode] 954. Array of Doubled Pairs 两倍数对儿数组
    上周热点回顾(8.3-8.9)团队
    发布新版首页“外婆新家”升级版:全新的UI,熟悉的味道团队
    上周热点回顾(7.27-8.2)团队
    终于换新颜:新版网站首页发布上线团队
    上周热点回顾(7.20-7.26)团队
  • 原文地址:https://www.cnblogs.com/feiyu_Team/p/6128089.html
Copyright © 2011-2022 走看看