Day 27 类的进阶-反射
11. __new__ 和 __metaclass__ 阅读以下代码: 1
2
3
4
5
6
class Foo(object): def __init__(self):
pass obj = Foo() # obj是通过Foo类实例化的对象
上述代码中,obj 是通过 Foo 类实例化的对象,其实,不仅 obj 是一个对象,Foo类本身也是一个对象,因为在Python中一切事物都是对象。 如果按照一切事物都是对象的理论:obj对象是通过执行Foo类的构造方法创建,那么Foo类对象应该也是通过执行某个类的 构造方法 创建。 1
2
print type(obj) # 输出:<class '__main__.Foo'> 表示,obj 对象由Foo类创建
print type(Foo) # 输出:<type 'type'> 表示,Foo类对象由 type 类创建
所以,obj对象是Foo类的一个实例,Foo类对象是 type 类的一个实例,即:Foo类对象 是通过type类的构造方法创建。
一、isinstance and issubclass
isinstance(obj,cls)检查是否obj是否是类cls的对象
#对象与类的关系
#判断第一个参数是否是第二个参数的实例
class A:pass
class B(A):pass
class C(B):pass
c = B()
print(isinstance(c,A)) #包含继承关系的判断.
#结果 True issubclass (sub,super)检查sub类是否是super类的派生类
#类与类之间的关系 print(issubclass(C,B))
#结果为True 二 、 反射 1.什么是反射
只要是指程序可以访问、检测和修改他本身状态或者
或行为的一种能力。
2. python面向对象中的反射:通过字符串的形式操作对象相关的属性,python中的一切事物都是对象(都可以使用反射)
四个可以实现自省的函数 下列方法适用于类和对象 hasattr(判断某一个变量是否能够调用一个名字,返回True或者False)
class Foo:
f ='类的静态变量'
def __init__(self,name,age):
self.name =name
self.age =age
def say_hi(self):
print("hi,%s " %self.name) obj= Foo('egon',73) # #检测是否还有某种属性
# print(hasattr(obj, 'name'))
# print(hasattr(obj,'sya_hi'))
# 打印结果:
# True# False
getattr (直接获取一个变量中的名字的值)
#获取属性
n= getattr(obj,'name')
print(n)
#结果:egon func =getattr(obj,'say_hi')
func()
#结果:hi, egon
# print(getattr(obj,'aaaaa',))#报错。
setattr (为一个变量增加或者修改一个属性)
# 设置属性
setattr(obj,'sb',1)
# setattr(obj,'show_name',lambda self:self.name+'sb')
print(obj.__dict__)
# 打印结果:{'name': 'egon', 'age': 73, 'sb': 1} # print(obj.show_name(obj))
delattr (删除一个变量中的属性或者方法)
delattr(obj,"age")
# delattr(obj,"show_name")
print(obj.__dict__)
#输出结果{'name': 'egon', 'sb': 1} a.b 的形式
d ={'k':'v'}
print(getattr(d,"key") 三、包的反射
def wahaha(self, a, b):
print(a, b) setattr(hei,'func',wahaha)
hei.func(hei,1,2) # f = open() #文件操作对象
# f.read() #文件对象,read 方法.
# 模块名.函数名 #此py文件名为my_moudle
money = 1000
def qqxing():
print('qqxing') #另外一个sheet
import my_module
# print(my_module.money)#结果为1000 #或者如下
print(getattr(my_module,'money'))#输出结果1000
getattr(my_module,'qqxing')()#结果为qqxing
def sww():
print('爽歪歪')
count =
import sys
import my_module
print(sys.modules[__name__]) #一定是当前的名字aaa.py
#结果为 : <module '__main__' from 'D:/parcharm/12/Day24/1.py'>
print(sys.modules['__main__'])# 不确定的。 <module '__main__' from 'D:/parcharm/12/Day24/1.py'>
print(getattr(sys.modules[__name__],'count')) #结果为
getattr(sys.modules[__name__],'sww')() #结果为爽歪歪
print(sys.modules[__name__]) #输出结果:<module '__main__' from 'D:/parcharm/12/Day24/1.py'>
print(sys.modules['my_module'])
# 结果 <module 'my_module' from 'D:\\parcharm\\my_module.py'>
print(my_module)
#结果<module 'my_module' from 'D:\\parcharm\\my_module.py'>
# 反射类中的名字
# getattr(类名,'静态属性')
# getattr(类名,'类方法')()
# getattr(类名,'静态方法')()
# 反射对象中的名字
# getattr(对象名,'对象属性')
# getattr(对象名,'方法名')()
# 反射模块中的名字
# import 模块名
# getattr(模块名,'模块中的变量')
# getattr(模块名,'模块中的函数')()
# getattr(模块名,'模块中的类名')
# 反射当前模块中的名字
# import sys
# getattr(sys.modules[__name__],'变量')
# getattr(sys.modules[__name__],'函数')()
# getattr(sys.modules[__name__],'类名')
# sys.modules[__name__]
# import sys
# print(sys.modules[__name__]) # 所有导入过的模块
# {'字符串数据类型的模块名':模块的内存地址}
# {'__main__':当前模块的内存地址}
# 怎么反射类 ?
class Student:
def __init__(self,name,age):
self.name = name
self.age = age
def show_student(self):
for key in self.__dict__:
print(key,self.__dict__[key])
class Teacher:
def __init__(self, name, age):
self.name = name
self.age = age
def show_teacher(self):
for key in self.__dict__:
print(key, self.__dict__[key])
class Manager:
def __init__(self, name, age):
self.name = name
self.age = age
def show_manager(self):
for key in self.__dict__:
print(key, self.__dict__[key])
# hei = Student('小黑',18)
import sys
main = sys.modules[__name__]
# import my_moudle
# cls = getattr(my_moudle,'Student')
# hei = cls('小黑',18)
# print(hei,hei.__dict__)
# 'Manager' 'Teacher' 'Student'
# 获取字符串数据类型的类名
cls_name = input('>>>')
# 根据输入反射找到具体的类
if hasattr(main,cls_name):
cls = getattr(main,cls_name)
# 实例化对象
alex = cls('alex',81)
print(type(alex))
# 展示这个对象中的所有方法
for i in alex.__dict__:
print(i,alex.__dict__[i])
# 用反射的知识 实现
# 写一个人类,这个人类 没有任何属性 实例化这个类 然后根据你的姓名和年龄为这个对象添加属性 (基础)
# 登录成功之后自动创建和用户身份匹配的类的对象 (提高)
Day 27 类的进阶-反射的更多相关文章
- python 类的进阶
类的进阶 一 isinstance(obj,cls)和issubclass(sub,super) class Foo: def __init__(self,name): self.name = nam ...
- Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究
Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究 一丶反射 什么是反射: 反射的概念是由Smith在1982年首次提出的 ...
- C# 直接创建多个类和使用反射创建类的性能
原文:C# 直接创建多个类和使用反射创建类的性能 本文告诉大家我对比的使用直接创建多个类和使用反射创建多个类的性能 在上一篇 C# 程序内的类数量对程序启动的影响 的基础上,继续做实验 现在创建 10 ...
- 2019-11-29-C#-直接创建多个类和使用反射创建类的性能
原文:2019-11-29-C#-直接创建多个类和使用反射创建类的性能 title author date CreateTime categories C# 直接创建多个类和使用反射创建类的性能 li ...
- 2019-8-31-C#-直接创建多个类和使用反射创建类的性能
title author date CreateTime categories C# 直接创建多个类和使用反射创建类的性能 lindexi 2019-08-31 16:55:58 +0800 2018 ...
- 044-PHP获得多个类对应的反射信息
<?php //获得多个类对应的反射信息 class demo{ public $str_1; private $str_2; protected $str_3; public function ...
- 043-PHP简单获得一个类对应的反射信息
<?php // 简单获得一个类对应的反射信息 class demo{ CONST CON_STR = '123456'; public $str_1; private $str_2; prot ...
- Python面向对象06 /元类type、反射、函数与类的区别、特殊的双下方法
Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 目录 Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 1. 元类type 2. 反射 3 ...
- python 面向对象专题(六):元类type、反射、函数与类的区别、特殊的双下方法
目录 Python面向对象06 /元类type.反射.函数与类的区别.特殊的双下方法 1. 元类type 2. 反射 3. 函数与类的区别 4. 特殊的双下方法 1. 元类type type:获取对象 ...
随机推荐
- spring-boot基础概念与简单应用
1.spring家族 2.应用开发模式 2.1单体式应用 2.2微服务架构 微服务架构中每个服务都可以有自己的数据库 3.微服务架构应当注意的细节 3.1关于"持续集成,持续交付,持续部署 ...
- CentOS 安装 Xamarin官方Mono
预先准备: 服务器可连入互联网 有yum 工具(没什么好说的,如果这个你没装,那重新装个系统吧,debian 等不要看这个,不一样的) wget 工具(可选) yum-uitl 工具包 导入Xamar ...
- Silverlight实用窍门系列:57.Silverlight中的Binding使用(二)-数据验证
本文将简单讲述Silverlight中的Binding数据时的数据验证. NotifyOnValidationError:是否在出现异常/错误信息的时候激发BindingValidationError ...
- oracle使用 merge 更新或插入数据
OracleCC++C# 总结下.使用merge比传统的先判断再选择插入或更新快很多. 1)主要功能 提供有条件地更新和插入数据到数据库表中 如果该行存在,执行一个UPDATE操作,如果是一个新行, ...
- PAT 1052 卖个萌 (20)(代码+思路)
1052 卖个萌 (20)(20 分) 萌萌哒表情符号通常由"手"."眼"."口"三个主要部分组成.简单起见,我们假设一个表情符号是按下列格 ...
- Reactor 模型(一)基本并发编程模型
Reactor 模型(一)基本并发编程模型 Netty 系列目录 (https://www.cnblogs.com/binarylei/p/10117436.html) 在讲解 Reactor 线程模 ...
- 【c3p0】 C3P0的三种配置方式以及基本配置项详解
数据库连接池C3P0框架是个非常优异的开源jar,高性能的管理着数据源,这里只讨论程序本身负责数据源,不讨论容器管理. ---------------------------------------- ...
- 【Win】使用ScreenToGif制作gif动态图片
ScreenToGif 经常要写各类教程,有时候需要制作一些演示动画,GIF动画图片是个不错的选择,ScreenToGif是一款GIF录屏软件,下载地址可自行百度. 运行环境 操作系统:windows ...
- JavaScript的异步运行机制
----异步运行机制如下: 1.左右同步任务都在主线程上执行,形成一个执行栈 2.主线程值外,还存在一个任务队列,只要异步任务有了运行结果,就在任务队列中放置一个事件 3.一旦执行栈中的所有同步任务执 ...
- 2018.09.15 poj1734Sightseeing trip(floyd求最小环)
跟hdu1599差不多.. 只是需要输出方案. 这个可以递归求解. 代码: #include<iostream> #include<cstdio> #include<cs ...