一. 反射

'''
# isinstance
class A:pass
class B(A):pass
a = A()
print(isinstance(a,A)) # 判断对象和类的关系
print(issubclass(B,A)) # 判断子类和父类的关系
print(issubclass(A,B))
'''
#--------------------------------------------------------------------------------#
# # 反射:是用字符串类型的名字,去操作变量
# # hasattr
# # getattr
# # setattr
# # delattr
# name = 1
# eval('print(name)') # 安全隐患
#
# # 反射 就没有安全问题
#
# # 反射对象中的属性和方法
# class A:
# def func(self):
# print('in func')
# a = A()
# a.name = 'alex'
# a.age = 63
# # 反射对象的属性
# ret = getattr(a,'name') # 通过变量名的字符串形式取到的值
# print(ret)
#
# # 变量名 = input('>>>') # func
# # print(getattr(a,变量名))
# # print(a.__dict__[变量名])
#
# # 反射对象的方法
# getattr(a,'func')() #--------------------------------------------------------------------------------#
'''
反射类的属性 class A:
price = 20
def func(self):
print('in func')
# A.price
print(getattr(A,'price')) '''
#--------------------------------------------------------------------------------#
'''
# 反射类的方法:classmethod staticmethod class A:
price = 20
@classmethod
def func(cls):
print('in func')
# A.func()
if hasattr(A,'func'): # 如果能找到则执行下面的语句
getattr(A,'func')() ''' #--------------------------------------------------------------------------------# # 模块 # 反射模块的属性 # import monday
# # print(monday.day) # monday
# print(getattr(monday,'day')) # # 反射模块的方法
# getattr(monday,'wahaha')() # 内置模块也能用 #----------------------------------------------------------------------------------# '''
year = 2018
import sys
# print(sys.modules['__main__'].year) # 2018 # 反射自己模块中的变量 def qqxing():
print('qqxing')
print(getattr(sys.modules['__main__'], 'year')) # 反射自己模块中的函数 # getattr(sys.modules['__main__'], 'qqxing')()
变量名 = input(">>>")
print(getattr(sys.modules[__name__],变量名)) '''
# import time
# x = input('>>>')
# print(getattr(time,x)()) # 一个模块中的类能不能反射得到? 能
# import monday
# getattr(monday,'C')
#
# if hasattr(monday,'year'):
# getattr(monday,'year') '''
# setattr 设置一个变量
class A:
pass
a = A()
setattr(a,'name','nezha') # 给a设置一个name为nezha
setattr(A,'name','alex') # 给A添加一个name为alex
print(a.name)
print(A.name) # delattr 修改一个变量
delattr(a,'name') # 删除的是对象a的name
print(a.name) # 对象a中找不到name,去A类中找到了
delattr(A,'name')
print(a.name) # 报错
'''

二. 类的内置方法

# 内置的类方法,和内置的函数之间有着千丝万缕的联系

# 双下方法

# obj.__str__

# print(str(1))
#
# # obj.__repr__
# print(1,'1')
# print(repr(1))
# print(repr('1'))
#
# class A:
# pass
# a = A()
# print(str(a)) # 现在a 里面找str,没找到 就找父类object的str方法 # <__main__.A object at 0x000001F60CEF0E48>
# # object 里有一个 __str__ ,一旦被调用,就返回调用这个方法的对象的内存地址
#
# class B:
# def __str__(self):
# return "B's object"
# def func(self):
# return 'wahaha'
# b = B()
# print(b) # 打印一个对象的时候,就是调用 b.__str__
# print(str(b))
#
# # l = [1, 2, 3, 4, 5] # 实例化了一个列表类的对象
# # print(l)
#
# print('%s:%s'%('B',b)) # %s str() 直接打印 实际上都是走的__str__ # class Teacher:
# def __init__(self, name, salary):
# self.name = name
# self.salary = salary
# def __str__(self):
# return "Teacher's object:%s"%self.name
# def func(self):
# return "wahah"
# alex = Teacher('alex',250)
# print(alex) # __repr__
#
# class Teacher:
# def __init__(self, name, salary):
# self.name = name
# self.salary = salary
# def __repr__(self):
# return str(self.__dict__)
# def func(self):
# return "wahah"
#
# alex = Teacher('alex',250)
# # print(repr(alex)) # %r repr() 实际上都是走的 __repr__
# # print('>>>%r'%alex)
#
# print(str(alex)) # 没有打印内存地址
# print('>>>%s'%alex) # repr 是 str 的备胎...反过来不可以(也就是str 不是 repr 的备胎) # print()/%s/str(obj)的时候,实际上是内部调用了obj.__str__方法,如果有str方法,那么他返回的必定是一个 字符串(必须是字符串,不能是数字等.)
# 如果没有__str__方法,会先找本类中的__repr__方法,在没有,再找父类中的__str__方法,若父类没有,就找__repr__...一直找到object中的__str__ # repr() 只会找__repr__ ,如果没有,就找父类的 # 所以 若 repr 和str只能实现一个方法的话 ,应该实现repr方法,因为str也可以用repr # 内置的方法有很多,不一定都在object中
# class A:
# pass
# # def __len__(self):
# # return 10
# a = A()
# print(len(a)) # object of type 'A' has no len()
#-------------------------------------------------------------------------#
# class Classes:
# def __init__(self, name):
# self.name = name
# self.student = []
# def __len__(self):
# return len(self.student)
#
# py_s9 = Classes('python全栈9期')
# py_s9.student.append('二哥')
# py_s9.student.append('哥')
# py_s9.student.append('二')
# print(len(py_s9)) # ----------------------------------------------------------------------------------- # # __del__
#
# class A:
# def __del__(self): # 析构函数:在删除一个对象之前进行一些收尾工作
# self.f.close()
# a = A()
# a.f = open() # 打开文件 ,第一 在操作系统中打开了一个文件 拿到了文件操作符存在了内存中
# del a # a.f 拿到了文件操作符消失在了内存中
#
# import time
# time.sleep(3)
# # del a # del 先执行了这个方法,然后再删除这个变量
#
# # 引用计数
#
# print(a) # -------------------------------------------------------------------------------------------------------------------- # # __call__
class A:
def __init__(self, name):
self.name = name
def __call__(self):
'''
打印这个对象中的所有属性
:return:
'''
for k in self.__dict__:
print(k,self.__dict__[k])
# a = A('alex')()
#
# a = A('alex')
# a() # 一个对象 加上括号 相当于执行__call__方法

python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法的更多相关文章

  1. python学习之老男孩python全栈第九期_day025知识点总结——接口类、抽象类、多态、封装

    一. 接口类 java:面向对象编程 设计模式 -- 接口类 接口类:python原生不支持 抽象类:python 原生支持的 from abc import abstractclassmethod, ...

  2. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  3. python学习之老男孩python全栈第九期_day016知识点总结

    '''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...

  4. python学习之老男孩python全栈第九期_day015知识点总结

    # 作用域相关(2)locals() # 返回本地作用域中的所有名字 globals() # 返回全局作用域中的所有名字 # 迭代器/生成器相关(3)range()print('__next__' i ...

  5. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  6. python学习之老男孩python全栈第九期_day020知识点总结——序列化模块、模块的导入和使用

    一. 序列化模块 # 序列化 --> 将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化# 反序列化 --> 从字符串转换成数据类型的过程叫做反序列化# 序列 -- 字符串 # 什 ...

  7. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  8. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  9. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

随机推荐

  1. react onclick传递参数

    最近在做react项目的时候,被一个小问题绊了一脚,记录一下 onClick 传入参数 onClick={e=>{this.Mallclose(e,index)} onClick={this.M ...

  2. 直接线性变换解法(DLT)用于标定相机

    直接线性变换法是建立像点坐标和相应物点物方空间坐标之间直接的线性关系的算法.特点:不需要内外方位元素:适合于非量测相机:满足中.低精度的测量任务:可以标定单个相机. 1 各坐标系之间的关系推导直接线性 ...

  3. python学习,day4:装饰器的使用示例

    ---恢复内容开始--- 装饰器:本质是函数,(装饰其他函数)就是为其他函数添加附加功能 装饰器有其独特的原则:1.不能修改被装饰的函数的源代码 2.不能修改被装饰的函数的调用方式 例子 import ...

  4. HDU - 6096 处理后缀的字典树

    题意:给定n个字符串,m次询问,每次询问多少个字符串前缀是pre且后缀是suf,前后缀不可相交 字典树同时存储前后缀,假设字符串长为len则更新2*len个节点,依次按s[0],s[len-1],s[ ...

  5. 获得自己电脑的SSH公匙

    关于什么是SSH请点击此"www.Baidu.com”网站了解 我这里只说怎么获取属于自己电脑的SSH公匙 本人是Win10电脑 所以相对来说简单一点  点击win ->选择设置-&g ...

  6. Android开发不可或缺的十大网站及工具

    1. Google 做开发前完全是小白,真心不知道有Google这东西,只晓得百度,遇到问题直接百度,不是黑百度,百度在娱乐八卦方面确实靠谱,但是技术方面查出来的东西基本千篇一律,有些答案甚至还会起到 ...

  7. Determining IP information for eth0...failed

    事故现场 eth0 Link encap:Ethernet HWaddr :0C::B6:D2:5A inet6 addr: fe80::20c:29ff:feb6:d25a/ Scope:Link ...

  8. Thread -- Request

    Servlet容器应该绝大部分(有可能全部)是Thread per Request,每个请求一个线程.此外有Thread per Connection,应该不是用于Servlet容器.请见 How a ...

  9. Go RabbitMQ(三)发布订阅模式

    RabbitMQ 在上一节中我们创建了工作队列,并且假设每一个任务都能够准确的到达对应的worker.在本节中我们将介绍如何将一个消息传递到多个消费者,这也就是所说的发布订阅模式 为了验证该模式我们使 ...

  10. redis数据类型(五)set类型

    一. set类型 set是无序集合,最大可以包含(2 的 32 次方-1)个元素. set 的是通过 hash table 实现的,所以添加,删除,查找的复杂度都是 O(1). hash table ...