1 反射

反射的精髓是通过字符串去获取对象属性的值

1.1 基于类和对象反射的属性

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 # 基于类和对象反射的属性
class People:
country = 'China'
def __init__(self,name):
self.name = name
def run(self):
print('%s is running'%self.name) p = People('egon') # 实例化一个People对象p
print('基于类和对象反射的属性')
# hasattr: 判断类或对象是否存在某个属性,存在返回True,否则返回False
print('hasattr------------>')
print(hasattr(p,'name'))
print(hasattr(People,'name'))
# getattr: 获取类或对象的属性
print('getattr------------->')
print(getattr(p,'run'))
print(getattr(People,'run'))
func = getattr(p,'run')
func() # hasattr和getattr结合使用
print('hasattr & getattr------------>')
if hasattr(p,'run'):
func = getattr(p,'run')
func() # setattr: 修改或新增类或对象的属性
print('setattr-------------->')
print(p.__dict__)
setattr(p,'name','cobila') # 用于修改
setattr(p,'age',18) # 用于新增
print(p.__dict__) # delattr: 删除类或对象的属性
print('delattr------------->')
print(p.__dict__)
delattr(p,'name')
print(p.__dict__)

1.2 基于当前模块反射的属性

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 import sys
x = 1111
class Foo:
pass def s1():
print('s1')
def s2():
print('s2') this_module = sys.modules[__name__] # 获取当前模块
print(this_module)
print(hasattr(this_module,'s1'))
print(getattr(this_module,'s1')) # print(this_module.s1)
print(hasattr(this_module,'s2'))
print(getattr(this_module,'s2')) # print(this_module.s2)

1.3 反射的应用1

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 import sys def add():
print('add')
def delete():
print('delete')
def update():
print('update')
def get():
print('get') this_module = sys.modules[__name__]
func_dict = {'add':add,'delete':delete,'update':update,'get':get}
while True:
choice = input('>>').strip()
if hasattr(this_module,choice):
func_dict[choice]

1.3 反射的应用2

FTP Client

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 class FtpClient:
'ftp客户端,但是还么有实现具体的功能'
def __init__(self,addr):
print('正在连接服务器[%s]'%addr)
self.addr = addr
# def get(self):
# print('get')

FTP Server

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 import ftp_client
f1 = ftp_client.FtpClient('192.168.1.1')
if hasattr(f1,'get'):
func_get = getattr(f1,'get')
func_get()
else:
print('Method get not found') print('处理其他逻辑') # 不影响其他功能实现

2 类内置attr

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 # class __getattr__ __setattr__ __delattr__
class Foo:
def __init__(self,name,age):
self.name = name # 会触发__setattr__
self.age = age # 会触发__setattr__ def __setattr__(self, key, value):
print('setattr')
if not isinstance(value,str): # 可以设置类型限制
raise TypeError("must be str")
self.__dict__[key] = value def __getattr__(self, item): # 属性不存在时会执行此函数
print('getattr') def __delattr__(self, item):
print('delattr')
self.__dict__.pop(item) f = Foo('egon',18) # 初始化会触发__setattr__
f.name = 'cobila' # 会触发__setattr__
print(f.__dict__)
f.xxx # 找不到xxx属性时会触发__getattr__
del f.age # 会触发__delattr__
print(f.__dict__)

3 定制自己的数据类型

3.1 继承的方式

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 # 定制自己的数据类型 通过继承
class List(list):
def append(self, p_object):
if not isinstance(p_object,int):
raise TypeError('Must be int')
super().append(p_object) def insert(self,index,p_object):
if not isinstance(p_object, int):
raise TypeError('Must be int')
super().insert(index,p_object) l1 = List([1,2,3])
print(l1)
l1.append(4)
print(l1)
# l1.append('test') # 会抛出TypeError异常
l1.insert(0,5)
# l1.insert(0,'5') # 会抛出TypeError异常
print(l1)

3.2 授权的方式

#!/usr/bin/env python
# __Author__: "wanyongzhen"
# Date: 2017/4/24 # 定制自己的open函数 不通过继承 通过授权的方式实现定制自己的数据类型
import time
print(time.strftime('%Y-%m-%d %X')) # 打印当前时间
class Open:
def __init__(self,filepath,mode='r',encoding='utf-8'):
self.filepath = filepath
self.mode = mode
self.encoding = encoding
self.f = open(filepath,mode,encoding=encoding)
def write(self,line):
t = time.strftime('%Y-%m-%d %X')
self.f.write('%s %s\n'%(line,t))
def __getattr__(self,item):
func = getattr(self.f,item)
return func f = Open('b.txt','w')
f.write('test write')
f.write('test write')
f.write('test write')
f.close() f = Open('b.txt','r+')
res = f.read()
print(res)
f.close()

Python全栈之路-Day31的更多相关文章

  1. Python全栈之路目录结构

    基础 1.Python全栈之路-----基础篇 2.Python全栈之路---运算符与基本的数据结构 3.Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数 4.Python全栈 ...

  2. Python全栈之路----目录

    Module1 Python基本语法 Python全栈之路----编程基本情况介绍 Python全栈之路----常用数据类型--集合 Module2 数据类型.字符编码.文件操作 Python全栈之路 ...

  3. Python全栈之路----常用模块----hashlib加密模块

    加密算法介绍 HASH       Python全栈之路----hash函数 Hash,一般翻译做“散列”,也有直接音译为”哈希”的,就是把任意长度的输入(又叫做预映射,pre-image),通过散列 ...

  4. python 全栈之路

    目录 Python 全栈之路 一. Python 1. Python基础知识部分 2. Python -函数 3. Python - 模块 4. Python - 面对对象 5. Python - 文 ...

  5. Python全栈之路----函数----返回值

    函数外部的代码想要获取函数的执行结果,就可以在函数里用return语句,把结果返回. def stu_register(name,age,course='PY',country='CN'): prin ...

  6. Python全栈之路----常用模块----软件开发目录规范

    目录基本内容 log  #日志目录 conf  #配置目录 core/luffycity  #程序核心代码目录  #luffycity 是项目名,建议用小写 libs/modules  #内置模块 d ...

  7. Python全栈之路----常用模块----shutil模块

    高级的 文件.文件包.压缩包 处理模块   参考Python之路[第四篇]:模块     #src是原文件名,fdst是新文件名 shutil.copyfileobj(fsrc, fdst[, len ...

  8. Python全栈之路----Python2与Python3

    金角大王Alex  python 之路,致那些年,我们依然没搞明白的编码 python2与python3的区别 py2 str = bytes 为什么有bytes? 是因为要表示图片.视频等二进制格式 ...

  9. Python全栈之路----函数进阶----装饰器

    Python之路,Day4 - Python基础4 (new版) 装饰器 user_status = False #用户登录后改为True def login(func): #传入想调用的函数名 de ...

随机推荐

  1. PowerDesigner建模应用(二)逆向工程,导出PDM文件前过滤元数据(表、视图、存储过程等)

    在上一篇文章<PowerDesigner建模应用(一)逆向工程,配置数据源并导出PDM文件>步骤二中导出了目标数据库对应的PDM文件, 该文件中展示出了所有表的信息与关系. 某些业务场景下 ...

  2. maven 的 snapshot 和 release 的区别

    release 是发行版,通常正式发布使用. snapshot 快照版本.在开发过程中,每提交一次修改,编译好响应的jar包,都会更新到仓库中,所有添加了这个jar包的依赖都会把远程仓库里的jar包更 ...

  3. 2017Java技术预备作业1501黄学超

    阅读邹欣老师的博客,谈谈你期望的师生关系是什么样的? 我觉得师生关系应当是亲密无间,课上老师讲解学生配合,课下师生交流启发思考. 你有什么技能(学习,棋类,球类,乐器,艺术,游戏,......)比大多 ...

  4. ubuntu如何进入local、bin目录

    回到home目录,输入命令:cd /usr/local 若要进入bin目录,输入命令:cd /usr/local/bin

  5. Python学习笔记之基本语法学习1

    ★学习目标: 用Python做HTTP接口测试 ★学习的大纲: ●Python语言基础(安装,第一个案例,基本语法等) ●Request模块使用 ●编写一个简单功能的接口测试案例 ●HTTP协议基础 ...

  6. javascript中的字符串编码、字符串方法详解

    js中的字符串是一种类数组,采用UTF-16编码的Unicode字符集,意味字符串的每个字符可用下标方式获取,而每个字符串在内存中都是一个16位值组成的序列.js对字符串的各项操作均是在对16位值进行 ...

  7. python生成二维码

    1.python-qrcode是个用来生成二维码图片的第三方模块,依赖于 PIL 模块和 qrcode 库. 首先,我们要安装三个模块,qrcode,image,PIL. pip install  q ...

  8. NIO(四、Selector)

    目录 NIO(一.概述) NIO(二.Buffer) NIO(三.Channel) NIO(四.Selector) Selector 前面两个章节都描述了Buffer和Channel,那这个章节就描述 ...

  9. 自动化利器-Zabbix

    1.1为何需要监控系统 在一个IT环境中会存在各种各样的设备,例如:硬件设备.软件设备.其系统的构成也是非常复杂的. 多种应用构成负载的IT业务系统,保证这些资源的正常运转,是一个公司IT部门的职责. ...

  10. MySQL(Navicat)运行.sql文件时报错[Err] 2006 - MySQL server has gone away 的解决方法

    在my.ini里加上  max_allowed_packet=16M