Python基础篇-day8
本节目录
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
Python基础篇-day8的更多相关文章
- python基础篇-day1
python基础篇 python是由C语言写的: pass 占位符: del,python中全局的功能,删除内存中的数据: 变量赋值的方法: user,pass = 'freddy','freddy1 ...
- python基础篇之进阶
python基础篇之进阶 参考博客:http://www.cnblogs.com/wupeiqi/articles/5115190.html python种类 1. cpython 使用c解释器生产 ...
- python基础篇(六)
PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...
- python基础篇(五)
PYTHON基础篇(五) 算法初识 什么是算法 二分查找算法 ♣一:算法初识 A:什么是算法 根据人们长时间接触以来,发现计算机在计算某些一些简单的数据的时候会表现的比较笨拙,而这些数据的计算会消耗大 ...
- python基础篇(一)
PYTHON基础篇(一) 变量 赋值 输入,输出和导入 A:输入 B:输出 C:导入 运算符 A:算数运算符 B:比较运算符 C:赋值运算符 D:位运算符 E:逻辑运算符 F:成员运算符 G:身份运算 ...
- python基础篇(二)
PYTHON基础篇(二) if:else,缩进 A:if的基础格式和缩进 B:循环判断 C:range()函数和len()函数 D:break,contiue和pass语句 for,while循环 函 ...
- python基础篇(三)
PYTHON基础篇(三) 装饰器 A:初识装饰器 B:装饰器的原则 C:装饰器语法糖 D:装饰带参数函数的装饰器 E:装饰器的固定模式 装饰器的进阶 A:装饰器的wraps方法 B:带参数的装饰器 C ...
- python基础篇(四)
PYTHON基础篇(四) 内置函数 A:基础数据相关(38) B:作用域相关(2) C:迭代器,生成器相关(3) D:反射相关(4) E:面向对象相关(9) F:其他(12) 匿名函数 A:匿名函数基 ...
- Python基础篇--输入与输出
站长资讯平台:Python基础篇--输入与输出在任何语言中,输入和输出都是代码最基础的开始,so,先来聊一聊输入和输出输出输入END在任何语言中,输入和输出都是代码最基础的开始,so,先来聊一聊输入和 ...
随机推荐
- sharepoint 使用命令行注册dll文件到gac的方法
使用命令行注册dll文件到gac的方法: gacutil.exe -i D:\SPFormLoginProject.dll 删除gac的dll方法: gacutil /u "SPFormLo ...
- 开源中文分词工具探析(三):Ansj
Ansj是由孙健(ansjsun)开源的一个中文分词器,为ICTLAS的Java版本,也采用了Bigram + HMM分词模型(可参考我之前写的文章):在Bigram分词的基础上,识别未登录词,以提高 ...
- java.lang.ClassNotFoundException: [Ljava.lang.String解决办法
原来jdk5.0的时候不会报这个错,用了jdk6.0就出现了这个错误,因为没有重载java.lang.String这个类 解决方法: 在vm缺省参数里添加-Dsun.lang.ClassLoader. ...
- 浅谈 JavaScript new 执行过程及function原理
前言 最近在学习JavaScript语言精粹,感觉写得相当不错.所以这里也算是总结一下.一个方法使用new的方式创建到底是怎样的过程,一个function的声明内部又是怎样执行的呢 另外学的过程中,不 ...
- for循环和while循环
for循环和while循环 --道心 for循环 name1_list=['daoxin','wuxin','zhixin']for ele in name1_list: #找到"wuxin ...
- kubernetes1.4 基础篇:Learn Kubernetes 1.4 by 6 steps
本教程受Kubernetes官方最新更新的文档所触发,之所以没有做单纯的翻译是因为如下几个原因: Kubernetes官方此教程基于minikube,个人对minikube可能有偏见,觉得像玩具. M ...
- CodeForces 749D Leaving Auction
二分查找,$set$. 对于某一次询问,如果把人删光了,那么输出$0$ $0$. 如果只剩下$1$个人,那么输出那个人喊的最低价格. 如果剩下的人数有大于等于两个, 这时最底下出现的情景必然是红色部分 ...
- linux面试题集锦《转》
1. 下面的网络协议中,面向连接的的协议是: A . A 传输控制协议 B 用户数据报协议 C 网际协议 D 网际控制报文协议 2. 在/etc/fstab文件中指定的文件系统加载参数中, D 参数一 ...
- svg动画学习
首先我们定义一块画布,然后在上面画一个圆形. 他看起来应该是这个样子的:(每一个实例我都会附加图片以及demo链接,方便直观的理解与源代码的查看,查看的时候请使用标准浏览器) 点击查看Demo 现在我 ...
- USB调试不能弹出授权窗口 unauthorized 的解决办法
今天把 AndroidStudio 1.5 给卸载了,重新安装 2.1版本,据说速度快了很多,结果手机一直没法授权调试,授权USB调试信任PC设备的窗口始终没看到,网上找了好多方法,什么驱动.重启.各 ...