python day21 ——面向对像-反射 getattr,内置方法
一、反射:用字符串数据类型的变量名来访问这个变量的值
上代码^_^
# class Student:
# ROLE = 'STUDENT'
# @classmethod
# def check_course(cls):
# print('查看课程了')
#
# @staticmethod
# def login():
# print('登录')
# # 反射查看属性
# # print(Student.ROLE)#普通方法
# # print(getattr(Student,'ROLE'))
#
# # 反射调用方法
# # getattr(Student,'check_course')() # 使用类中的方法
# # getattr(Student,'login')() # 使用静态方法
用对象来反射
# class A():
# def __init__(self,name):
# self.name = name
#
# def func(self):
# print('in func')
#
# a = A('alex')#实例化一个对象
# print(a.name)
# print(getattr(a,'name'))#获得属性值
# getattr(a,'func')()#执行方法
是不是还挺好理解的啊!!
模块角度
好像是不是有xxx.xxx就能用到啊,模块四不四 from xxx import xxx.xxx啊,对就能用。
# import os # 别人写好的python代码的结合
# # os.rename('__init__.py','init')#改文件名的功能
# # getattr(os,'rename')('init','__init__.py') #功能和上面一样后面是参数。
# rename = os.rename
# rename2 = getattr(os,'rename')
# rename2('__init__.py','init') # os.rename('__init__.py','init')
# rename('init','init2') # os.rename('init','init2')
下一个是 反射自己模块中的内容 找到自己当前文件所在的命名空间。这个有点不好理解,不过聪明人会先记住有机会慢慢在理解。
# import sys
# print(sys.modules)#查看当前模块,返回的是一个字典
# import 都相当于导入了一个模块
# 模块哪个导入了 哪个没导入 在我的python解释器里应该记录下来
# import sys 是一个模块,这个模块里的所有的方法都是和python解释器相关的
# sys.modules 这个方法 表示所有在当前这个python程序中导入的模块
# '__main__': <module '__main__' from 'D:/sylar/python_workspace/day20/4.反射.py'>
# print(sys.modules['__main__'])
# my_file = sys.modules['__main__']#这个先记住
# my_file.wahaha()
# my_file.qqxing()
# # 'qqxing'
# # 'wahaha'
# getattr(my_file,'wahaha')()
# getattr(my_file,'qqxing')()
总结下
# 反射
# hasattr,getattr
# 类名.名字
# getattr(类名,'名字')
# 对象名.名字
# getattr(对象,'名字')
# 模块名.名字
# import 模块
# getattr(模块,'名字')
# 自己文件.名字
# import sys
# getattr(sys.modules['__main__'],'名字')
下面来个实际应用场景,理解后背下来自己敲一便。
# class Manager:
# OPERATE_DIC = [
# ('创造学生账号', 'create_student'),
# ('创建课程','create_course'),
# ('查看学生信息','check_student_info'),
# ]
# def __init__(self,name):
# self.name = name
# def create_student(self):
# print('创建学生账号')
# def create_course(self):
# print('创建课程')
# def check_student_info(self):
# print('查看学生信息')
#
# class Student:
# OPERATE_DIC = [
# ('查看所有课程', 'check_course'),
# ('选择课程', 'choose_course'),
# ('查看已选择的课程', 'choosed_course')
# ]
# def __init__(self,name):
# self.name = name
# def check_course(self):
# print('check_course')
# def choose_course(self):
# print('choose_course')
# def choosed_course(self):
# print('查看已选择的课程')
#
# def login():
# username = input('user : ')
# password = input('pwd : ')
# with open('userinfo') as f:
# for line in f:
# user,pwd,ident = line.strip().split('|') # ident = 'Manager'
# if user == username and pwd == password:
# print('登录成功')
# return username,ident
#
# import sys
# def main():
# usr,id = login()
# print('user,id :',usr,id)
# file = sys.modules['__main__']
# cls = getattr(file,id) #Manager = getattr(当前文件,'Manager'),获得对应的类
# obj = cls(usr)
# operate_dic = cls.OPERATE_DIC
# while True:
# for num,i in enumerate(operate_dic,1):
# print(num,i[0])
# choice = int(input('num >>>'))
# choice_item = operate_dic[choice-1]
# getattr(obj,choice_item[1])()
#
#
#
# main()
主要是实现登陆和特定人员的选择和更改。
二、内置方法:有些函数里面带了特定的方法,比如len()里面可能有__len__这个方法
# __名字__
# 类中的特殊方法\内置方法
# 双下方法
# 魔术方法 magic_method
# 类中的每一个双下方法都有它自己的特殊意义 1.__call__
# class A:
# def __call__(self, *args, **kwargs):
# print('执行call方法了')
# def call(self):
# print('执行call方法了')
# class B:
# def __init__(self,cls):
# print('在实例化A之前做一些事情')
# self.a = cls()
# self.a()
# print('在实例化A之后做一些事情')
# a = A()
# a() # 对象() == 相当于调用__call__方法
# a.call()#就调用类里面的__call__方法了
# A()() # 类名()() ,相当于先实例化得到一个对象,再对对象(),==>和上面的结果一样,相当于调用__call__方法
# B(A)
2.__len__
# 内置函数和类的内置方法是由奸情的
# class My:
# def __init__(self,s):
# self.s = s
# def __len__(self):
# return len(self.s)
# my = My('abc')
# print(len(my))
3.__new__
# class Single:
# def __new__(cls, *args, **kwargs):
# obj=object.__new__(cls)
# print('在new方法里',obj)
# return obj
# def __init__(self):
# print('在init方法里',self)
#执行顺序
#1.开辟一个空间,属于对象的
#2.把对象的空间传给self,执行init
#3.将这个对象的空间返回给调用者
#new 方法在什么时候执行?
#在实例化对象之后,__init__之前先执行__new__来创建一块空间 单例类,背下来面试题
class Single:
__isinstance=None
def __new__(cls, *args, **kwargs):
if not cls.__isinstance:
cls.__isinstance=object.__new__(cls)
return cls.__isinstance
def __init__(self,name,age):
self.name=name
self.age=age
print( self) a=Single('aaa',56)
b=Single('sdf',55)
print(a.name)
只要前面实例化一个对象,就会开辟一个内存空间。后面的实例化对象不能开辟新的内存空间,后面的对象传进去的参数会覆盖前面对象的参数。
python day21 ——面向对像-反射 getattr,内置方法的更多相关文章
- python 面向对象之反射及内置方法
		
面向对象之反射及内置方法 一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静 ...
 - Python反射和内置方法(双下方法)
		
Python反射和内置方法(双下方法) 一.反射 什么是反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发 ...
 - 面向对象(五)——isinstance与issubclass、反射、内置方法
		
isinstance与issubclass.反射.内置方法 一.isinstance与issubclass方法 1.isinstance是用来判断对象是否是某个类 isinstance(obj,cla ...
 - Python学习day08-python进阶(2)-内置方法
		
Python学习day08-python进阶(2)-内置方法 列表数据类型内置方法 作用 描述多个值,比如爱好 定义方法 xxxxxxxxxx 2 1 hobby_list ...
 - python面向编程;类的绑定与非绑定方法、反射、内置方法
		
一.类的绑定与非绑定方法 ''' 类中定义函数分为了两大类: 1. 绑定方法 特殊之处: 绑定给谁就应该由谁来调用,谁来调用就会将谁当做第一个参数自动传入 绑定给对象的方法: 在类中定义函数没有被任何 ...
 - python面向对象 : 反射和内置方法
		
一. 反射 1. isinstance()和issubclass() isinstance( 对象名, 类名) : 判断对象所属关系,包括父类 (注:type(对象名) is 类名 : 判断对象所属 ...
 - Python之路(第二十五篇) 面向对象初级:反射、内置方法
		
[TOC] 一.反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它 ...
 - 《Python》反射、内置方法(__str__,__repr__)
		
一.反射 通过字符串的形式操作对象相关的属性.(使用字符串数据类型的变量名来获取这个变量的值) Python中的一切事物都是对象(都可以使用反射) 反射类中的变量 反射对象中的变量 反射模板中的变量 ...
 - python 反射和内置方法
		
一.isinstance和issubclass class Foo: pass class Son(Foo): pass s = Son() #判断一个对象是不是这个类的对象,传两个参数(对象,类) ...
 
随机推荐
- 键盘录入一个文件夹路径,统计该文件夹(包含子文件夹)中每种类型的文件及个数,注意:用文件类型(后缀名,不包含.(点),如:"java","txt")作为key, 	用个数作为value,放入到map集合中,遍历map集合
			
package cn.it.zuoye5; import java.io.File;import java.util.HashMap;import java.util.Iterator;import ...
 - 在vue项目中 如何定义全局变量 全局函数
			
如题,在项目中,经常有些函数和变量是需要复用,比如说网站服务器地址,从后台拿到的:用户的登录token,用户的地址信息等,这时候就需要设置一波全局变量和全局函数 定义全局变量 原理: 设置一个专用的的 ...
 - 尚硅谷面试第一季-18ES与Solr的区别
			
背景:它们都是基于Lucene搜索服务器基础之上开发,一款优秀的,高性能的企业级搜索服务器.[是因为他们都是基于分词技术构建的倒排索引的方式进行查询] 开发语言:Java语言开发 诞生时间:Solr ...
 - 【做题】SDOI2017硬币游戏——方程&概念处理
			
原文链接 https://www.cnblogs.com/cly-none/p/9825339.html 题意:给出\(n\)个长度为\(m\)的互不相同的01串.有另一个串,初始为空.不断进行如下操 ...
 - 获取Tomcat更详细的日志
			
前言 有时候tomcat报错未详细,未能定位到原因. 解决方法: 获取更详细的日志,以便调试. 详细步骤: 获取详细的日志,方法如下: 在WEB-INF/classes目录下logging.pro ...
 - python版 mapreduce 矩阵相乘
			
参考张老师的mapreduce 矩阵相乘. 转载请注明:来自chybot的学习笔记http://i.cnblogs.com/EditPosts.aspx?postid=4541939 下面是我用pyt ...
 - JVM(二)之GC(转)
			
一.为什么需要垃圾回收 如果不进行垃圾回收,内存迟早都会被消耗空,因为我们在不断的分配内存空间而不进行回收.除非内存无限大,我们可以任性的分配而不回收,但是事实并非如此.所以,垃圾回收是必须的. 二. ...
 - JxBrowser之三:常用函数setNetworkDelegate
			
1.常用函数setNetworkDelegate,包含对网络传输数据状态的多种监控回调. 2.着重说一下其中的几个函数 BrowserContext browserContext = BrowserC ...
 - Django 编写模板并渲染的示例
			
>>> from django.template import Template, Context >>> raw_template = ""& ...
 - Lab 9-2
			
Analyze the malware found in the file Lab09-02.exe using OllyDbg to answer the following questions. ...