博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
类与反射
阅读量:6388 次
发布时间:2019-06-23

本文共 5477 字,大约阅读时间需要 18 分钟。

本节目录

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:\Python\Python3\python.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("\033[31;1mHas changed the flight status to \033[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:\Python\Python3\python.exe D:/python培训/our_python/day8/app.py
>>:login
请输入用户名、密码
>>:logout
跳转到登录界面
>>:asd
404

转载于:https://www.cnblogs.com/feiyu_Team/p/6128089.html

你可能感兴趣的文章
双十一流量洪峰 支撑阿里核心业务的云数据库揭秘
查看>>
Docker镜像存储系统Speedy
查看>>
Jetty源码学习8-HttpClient
查看>>
微信渠道二维码怎么使用?
查看>>
RHEL7 systemd与RHEL5 init区别
查看>>
微服务的断路器实现图解Golang通用实现
查看>>
微信打开网址提示浏览器打开的通用遮罩
查看>>
shell 脚本 99例
查看>>
Python 中读取和保存图像方法汇总及其区别
查看>>
Linux挂载大于2T的磁盘
查看>>
Windows 8/Server 2012 离线安装 .Net 3.5
查看>>
我的友情链接
查看>>
linux 运行期进程感染(Infection)
查看>>
Linux 反引号 的作用
查看>>
MyEclipse验证JS文件时卡死
查看>>
php匹配指定标签的内容
查看>>
主线程中调用WaitForSingleObject函数造成的死锁问题
查看>>
MongoDB之基础篇
查看>>
windbg 查内存泄露
查看>>
文字資料要用哪種資料型別儲存char, varchar, nchar, nvarchar
查看>>