python之路(9)反射、包装类、动态模块导入
目录
反射
python提供自省的四个方法:
hasattr(object,name) 判断object中有没有有个name字符串对应对应的方法和属性
class demo:
name = 'chen'
age = '22'
def test_func(self):
print("存在") hasattr(demo, 'test_func') #True
hasattr(demo, 'name') #True
hasattr(demo, 'date') #False
(常用)getattr(object,name,default=None) 根据name字符串寻找object中对应的数据属性或函数属性,相当于object.name
class demo:
name = 'chen'
age = '22'
def test_func(self):
print("存在") getattr(demo, 'test_func') #<function demo.test_func at 0x00000264F0ABA9D8>
getattr(demo, 'name') #chen
getattr(demo, 'date') #报错
setattr(object,name,value) 根据name字符串去设置或修改object中相对应的数据属性或函数属性,相当于object.name=value
class demo:
name = 'chen'
age = '22'
def test_func(self):
print("存在") #设置数据属性
setattr(demo,'date','2018/11/21')
print(getattr(demo, 'date')) #2018/11/21
#设置函数属性
setattr(demo,'test2_func',lambda x:x+2)
print(getattr(demo, 'test2_func')(8)) #10
delattr(object,name) 根据name字符串去删除object中相对应的数据属性或函数属性,相当于del object.name
class demo:
name = 'chen'
age = '22'
def test_func(self):
print("存在") delattr(demo,'name')
反射使用类中用到的三个内置函数
(常用)_getattr_ 当访问的属性找不要的时候执行这个这个函数
class demo:
def __init__(self,name,age):
self.name = name
self.age = age def __getattr__(self, item):
print("不存在%s属性"%item) d1 = demo('chen',22)
#调用不存在的属性
d1.data #不存在data属性
补充:
_getattribute_ 当访问属性时,无论属性存不存在,都会执行,当与_getattr_函数同时存在时,优先执行_getattribute_ ,忽略_getattr_函数。
所以_getattr_是在_getattribute_ 中抛出一个AttributrError时才会执行
class demo:
def __init__(self,name,age):
self.name = name
self.age = age def __getattr__(self, item): #会被忽略
print("这里是getattr") def __getattribute__(self, item):
print("这里是getattribute")
# raise AttributeError('抛出异常') d1 = demo('chen',22)
#调用不存在的属性
d1.data #这里是getattribute class demo:
def __init__(self,name,age):
self.name = name
self.age = age def __getattr__(self, item):
print("这里是getattr") def __getattribute__(self, item):
print("这里是getattribute")
raise AttributeError('抛出异常') #抛出异常,会调用__getattr__方法去执行 d1 = demo('chen',22)
#调用不存在的属性
d1.data #这里是getattribute\n这里是getattr
_setattr_ 当赋值属性值时执行这个函数
class demo:
def __init__(self,name,age):
self.name = name #赋值操作
self.age = age #赋值操作 def __setattr__(self, key, value):
print("key:%s value:%s"%(key,value))
self.__dict__[key]=value d1 = demo('chen',22) #key:name value:chen key:age value:22
_delattr_ 当删除属性事执行这个函数
class demo:
def __init__(self,name,age):
self.name = name #赋值操作
self.age = age #赋值操作 def __delattr__(self, item):
print("删除%s"%item)
self.__dict__.pop(item) d1 = demo('chen',22)
del d1.name #删除name
变量赋值操作的自定制之所有字符串大写
class demo:
def __init__(self,name,age):
self.name = name #赋值操作
self.age = age #赋值操作 def __setattr__(self, key, value):
if type(value) is str:
self.__dict__[key] = value.upper() #制定大写
else:
self.__dict__[key] = value d1 = demo('chen',22)
print(d1.__dict__) #{'name': 'CHEN', 'age': 22}
利用继承二次包装标准类
class List(list):
def append(self, value):
if type(value) is str:
super().append(value)
else:
print('只能添加字符串类型') def show_midlle(self): #求列表中间的value
mid_index=int(len(self)/2)
return self[mid_index] l1=List('chen')
l1.append(12) #只能添加字符串类型
l1.show_midlle() #e
利用授权二次包装标准类
授权也是一种包装,但不是通过继承去实现,利用_getattr_实现
import time
class FileHandle:
def __init__(self,filename,mode='r',encoding='utf-8'):
#已实现的功能,依然用原来的功能
self.file=open(filename,mode,encoding=encoding) # 定制在写入文件时,写入时间的写函数
def write(self,line):
t=time.strftime('%Y-%m-%d %X')
self.file.write('%s %s' %(t,line)) #如果访问的属性不纯在
def __getattr__(self, item): return getattr(self.file,item) f1=FileHandle('a.txt','w+',encoding='utf-8') f1.write('第一条\n')
f1.write('第二条\n')
f1.write('第三条\n')
2018-11-21 19:11:07 第一条
2018-11-21 19:11:07 第二条
2018-11-21 19:11:07 第三条
动态导入模块
# 导入的是m1,不是m1下的t文件
# 这样导入的是路径最顶层的模块
module_t = __import__('m1.t') #
print(module_t) #<module 'm1' (namespace)>
module_t.t.test3() #这里是t模块 #利用模块导入
import importlib
#导入的是m1下的t文件
m = importlib.import_module("m1.t")
print(m) # <module 'm1.t' from 'F:\\PyCharm 2018.2.3\\PycharmProjects\\chen\\day13\\m1\\t.py'>
m.test3() #这里是t模块
python之路(9)反射、包装类、动态模块导入的更多相关文章
- isinstance和issubclass、动态模块导入、异常处理
一.isinstance和issubclass isinstance:判断某个对象是否是某个类的实例,返回True或Flase issubclass:判断某个类是否是某个类的子类. 例如: class ...
- python之路第五篇之模块和加密算法(进阶篇:续)
模块 Python中,如果要引用一些内置的函数,该怎么处理呢?在Python中有一个概念叫做模块(module) 简单地说,模块就是一个保存了Python代码的文件. 模块分类: 1)内置模块 2)自 ...
- Python之路(第二十篇) subprocess模块
一.subprocess模块 subprocess英文意思:子进程 那什么是进程呢? (一)关于进程的相关理论基础知识 进程是对正在运行程序的一个抽象,进程的概念起源于操作系统,是操作系统最核心的概念 ...
- python 装饰器、递归原理、模块导入方式
1.装饰器原理 def f1(arg): print '验证' arg() def func(): print ' #.将被调用函数封装到另外一个函数 func = f1(func) #.对原函数重新 ...
- python之路(8)常用模块
目录 os模块 sys模块 json模块 pickle模块 xml模块 re模块 logging模块 configparser模块 hashlib模块 time模块 random模块 subproce ...
- Python之路(第十七篇)logging模块
一.logging模块 (一).日志相关概念 日志是一种可以追踪某些软件运行时所发生事件的方法.软件开发人员可以向他们的代码中调用日志记录相关的方法来表明发生了某些事情.一个事件可以用一个可包含可选变 ...
- Python之路(第二十一篇) re模块
一.re模块 正则表达式本身是一种小型的.高度专业化的编程语言,正则表达式就是字符串的匹配规则,在多数编程语言里都有相应的支持,python里对应的模块是re,正则表达式模式被编译成一系列的字节码,然 ...
- Python之路(第十三篇)time模块、random模块、string模块、验证码练习
一.time模块 三种时间表示 在Python中,通常有这几种方式来表示时间: 时间戳(timestamp) : 通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量.(从 ...
- python动态模块导入
首先创建一个模块目录lib,然后在目录内创建一个模块为:aa.py 官方推荐: import importlib aa = importlib.import_module('lib.aa') c = ...
随机推荐
- 常见的异步方式async 和 await
之前研究过c#的async和await关键字,幕后干了什么,但是不知道为什么找不到相关资料了.现在重新研究一遍,顺便记录下来,方便以后查阅. 基础知识 async 关键字标注一个方法,该方法返回值是一 ...
- <自动化测试方案_8>第八章、手机端UI自动化测试
第八章.手机端UI自动化测试 (一)APP测试分类 1,原生APP:Native页面是使用原生系统内核的,相当于直接在系统上操作 2,H5APP:先调用系统的浏览器内核,相当于是在网页中进行操作,较原 ...
- Delphi IfThen语句
function IfThen(AValue: Boolean; const ATrue: string; AFalse: string = ''): string; overload; $[StrU ...
- vue watch监听验证码时,axios延迟发送post请求。
标题写的全面一些,方便其他人检索,我就是找了半天找不到资料,最后自己搞定了. 原理: 每次监听到输入值变化,就打一个时间戳,然后暂停2秒再去提交post验证. 但是每次提交前,判断一下之前打的时间戳和 ...
- SpringBoot Mybatis 使用LocalDateTime
mybatis-spring-boot-starter 2.0.1 会报错,不知道如何解决(建议先不用) mybatis-spring-boot-starter 2.0.1 - 1.3.2 版本不会报 ...
- win 10 精简组件列表
轻松访问工具 操作中心 应用程序虚拟化(App-V) Telemetry Client (Asimov)(遥测) Assigned Access(按需访问) 自动播放 网络后台传输 备份 生物识别服务 ...
- jQuery的一些简单基础知识
### 什么是jQuery?jQuery(js+Query)是一款优秀的JavaScript库,帮助开发人员用最少的代码做更多的事情,官网网站http://jquery.com/ ### 为什么学习j ...
- 前序遍历构造已知二叉树(Java)
public BiNode createBiTree() { Scanner input = new Scanner(System.in); int k = input.nextInt(); if(k ...
- C#编程风格
开始实习之后,才发现自己是多么地菜.还有好多东西还要去学习. 公司很好,还可以帮你买书.有一天随口问了一下上司D,代码规范上面有什么要求.然后D在Amazon上面找到了这本书<C#编程风格(Th ...
- mysql创建函数之省市区数据查询
DROP FUNCTION IF EXISTS queryChildrenAreaInfo;CREATE FUNCTION queryChildrenAreaInfo(areaId varchar(2 ...