python之面向对象函数与方法,反射,双下方法
一、函数和方法
1.函数和方法的区别
函数: 全都是显性传参,手动传参,与对象无关
方法: 存在隐性传参,与对象有关
1.1通过函数名可以判断
len()就是函数
str.count()就是方法
def func():
pass
class A:
def func(self):
print(func)
obj = A()
print(obj.func())
2.2通过types模块判断
from types import functionType
from types import MethodType
print(isinstance(func,FunctionType))
print(isinstance(func,MethodType))
- 类名调用func就是一个函数
- 对象调用func就是一个方法
2.3 对于静态方法的研究
print(isinstance(A.f, FunctionType)) #指的是函数类型
print(isinstance(A.f, MethodType)) #类方法
二、反射
有什么用
有些时候你明明知道一个变量的字符串数据类型的名字,你想调用它,但是调不到,就可以使用反射
反射方法
通过字符串去操作一个对象
getattr 获取一个属性或者方法
getattr(obj,'name1',None) #前面是类名,后面是字符串形式的属性或方法
hasattr 判断属性或方法是否存在
hasattr(obj,'name')
setattr 设置新的属性
setattr(obj,'hobby', '玩')
hasattr 删除属性
hasattr(obj, 'func')
对实例化对象的反射
前面是实例化对象名,后面是字符串形式的实例化对象的属性
class Foo:
f = '类的静态变量'
def __init__(self, name, age):
self.name = name
self.age = age
def say_hi(self):
print(f'hi,{self.name}')
obj = Foo('egon', 73)
# 检测是否含有某属性 name
print(hasattr(obj, 'name'))
print(hasattr(obj, 'say_hi'))
# 获取属性
n = getattr(obj, 'name') # 等同于 obj.name
print(n)
func = getattr(obj, 'say_hi')
func()
# print(getattr(obj, 'aaaaaaaa', '不存在啊')) # 报错
# 设置属性
setattr(obj, 'sb', True) # 等同于 obj.sb = True
setattr(obj, 'show_name', lambda self: self.name + 'sb')
print(obj.__dict__)
print(obj.show_name(obj))
# 删除属性
delattr(obj, 'age') # 等同于 del obj.age
delattr(obj, 'show_name')
# delattr(obj, 'show_name111') # 不存在,则报错
print(obj.__dict__)
对类的反射
前面是类名,后面是字符串形式的类的属性或方法
class Foo(object):
staticField = "old boy"
def __init__(self):
self.name = 'wupeiqi'
def func(self):
return 'func'
@staticmethod
def bar():
return 'bar'
print(getattr(Foo, 'staticField')) # 前面是类名,后面是类的属性或方法
print(getattr(Foo, 'func'))
print(getattr(Foo, 'bar'))
对当前模块的反射
import sys
def s1():
print('s1')
def s2():
print('s2')
this_module = sys.modules[__name__] # 比较推荐#sys.modules 获得到的是 当前文件的所有属性及方法,返回是一个字典
# 等同于 this.module = sys.modules["__main__"]
hasattr(this_module, 's1')
getattr(this_module, 's2')()
对其他模块的反射
"""
程序目录:
module_test.py
index.py
"""
# module_test.py 中的代码
def test():
print('from the test')
# index.py 中的代码
import module_test as obj
# obj.test()
print(hasattr(obj, 'test'))
getattr(obj, 'test')()
class A:
static_field = '静态属性'
def __init__(self, name, age):
self.name = name
self.age = age
def func(self):
print('in A func')
obj = A('MC骚Q', 18)
print(obj.name)
#
print(hasattr(obj,'name')) # ***
print(getattr(obj,'name1',None)) ***
setattr(obj,'hobby', '玩') *
print(getattr(obj,'hobby'))
print(obj.hobby)
delattr(obj,'name') *
print(hasattr(obj,'name'))
if hasattr(obj, 'static_field'):
print(getattr(obj,'static_field'))
if hasattr(obj, 'func'):
# print(getattr(obj,'func'))
getattr(obj,'func')()
三、双下方法
__len__
用途
可以获取类中属性个数,如__init__中
格式
def __len(self):
print('触发__len__方法')
return 10
触发方法
len(obj)
一个对象之所以可以使用len()函数,根本原因是你这个对象从输入的类中有__len__方法,方法其实执行的是 len 当类中没有__len__ 这个方法时,使用len()就会报错
__hash__
用途
哈希
触发方法
print(hash(obj))
__str__方法
用途
打印输出
触发方法
print(obj)
__repr__方法
用途
同__str__一样,与str同时存在的时候,str的优先级要高
触发方法
print(此对象是%r那就先执行repr的方法)
__call__方法
触发方法
obj() #对象加括号触发就会触发类里面的__call__方法
__eq__方法
用途
当你对一个类中的两个对象比较操作的时候,就会触发__eq__方法
__del方法
有什么用
对象引用为零的时候, 析构方法,主动删除
从内存中删除,垃圾回收机制♻️
调用方法
l2 = [1,2,3]
dic = {1:22, 2:33}
del l2
del dic #主动删除
__new__(*****************)
用什么用
- 构造一个对象出来(自动执行
__init__文件的时候就是__new__在干这件事儿) - 创建构建并返回一个新的空间
class A(object):
def __init__(self):
print('in __init__')
def __new__(cls, *args, **kwargs):
print('in __new__')
object1 = object.__new__(cls)
return object1
obj = A()
# 输出结果
in __new__
in __init__
单例模式
单例模式单例模式就是一种设计模式,一个类智能实例化一个对象,无论你实例化多少次,内存中都只有一个对象,目的是为节省 空间
面试几乎都会让你手写一个单例模式
class A:
__instance = None
def __new__(cls, *args, **kwargs):
if not cls.__instance:
object1 = object.__new__(cls)
cls.__instance = object1
return cls.__instance
obj = A()
obj1 = A()
obj2 = A()
obj3 = A()
print(obj, obj1, obj2, obj3)
__item__方法
用途
对对象进行类似于字典的操作
__getitem__、__setitem__、__delitem__、
class Foo:
def __init__(self, name):
self.name = name
def __getitem__(self, item):
print(item)
print('get时 执行我')
def __setitem__(self, key, value):
self.name = value
print('set时执行我')
def __delitem__(self, key):
print(f'del obj{[key]}时,我执行')
obj = Foo('御姐')
# obj.__dict__
# obj['name']
# obj['name'] = '萝莉'
# print(obj.name)
del obj['name']
class Foo:
def __init__(self, name, key, value):
self.name = name
self.dict = {}
self.dict[key] = value
def __getitem__(self, key):
print("1313", self.dict[key])
# return self.dict[key]
def __setitem__(self, key, value):
self.__dict__[key] = value
print(key, "创建新的键值对")
def __delitem__(self, key):
print('del obj[', key, ']时,我执行')
self.__dict__.pop(key)
def __delattr__(self, item):
print('del obj.', item, '时,我执行')
self.__dict__.pop(item)
f1 = Foo("sb", "A", "1")
f1["A"] # 会去执行 __getitem__ 方法
f1['age'] = 18 # 会去执行 __setitem__ 方法
f1['age'] = 112 # 修改也会去执行 __setitem__ 方法
f1['age1'] = 250 # 修改也会去执行 __setitem__ 方法
del f1.age1 # 会去执行 __delattr__ 方法
del f1['age'] # 会去执行 __delitem__ 方法
f1['name'] = 'alex' # 会去执行 __setitem__ 方法
print(f1.__dict__)
利用类方法的认证功能***
class Auth:
function_list = [('login','请登录'),('register','请注册'),('exit_q','退出')]
def login(self):
print('欢迎登录')
def register(self):
print('欢迎注册')
def exit_q(self):
print('退出程序')
exit()
while 1:
obj = Auth()
for num,option in enumerate(obj.function_list,1):
print(num,option[1])
try:
choice_num = input('请输入选择: ').strip()
if hasattr(obj,obj.function_list[int(choice_num)-1][0]):
getattr(obj,obj.function_list[int(choice_num)-1][0])()
except IndexError:
print('请输入超过范围')
except ValueError:
print('请输入数字')
python之面向对象函数与方法,反射,双下方法的更多相关文章
- 百万年薪python之路 -- 面向对象之 反射,双下方法
面向对象之 反射,双下方法 1. 反射 计算机科学领域主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省) python面向对象中的反射:通过字符串的形式操作对象相关的属性.python ...
- Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究
Python进阶----反射(四个方法),函数vs方法(模块types 与 instance()方法校验 ),双下方法的研究 一丶反射 什么是反射: 反射的概念是由Smith在1982年首次提出的 ...
- Python反射和内置方法(双下方法)
Python反射和内置方法(双下方法) 一.反射 什么是反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发 ...
- Python面向对象之反射,双下方法
一. 反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被程序 ...
- python之路-双下方法
双下方法 定义: 双下方法是特殊方法,他是解释器提供的,由双下线加方法名加双下划线 __方法名__具有特殊意义的方法 双下方法主要是Python源码程序员使用的,元编程 我们在开发中尽量不要使用双下方 ...
- 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:获取对象 ...
- day26——tyoe元类与object的联系、反射、函数与方法的区别、双下方法
day26 type元类与object联系 type 获取对象从属于的类 python 中一切皆对象, 类在某种意义上也是一个对象,python中自己定义的类,以及大部分内置类,都是由type元类(构 ...
- Python面向对象 | 双下方法
定义:双下方法是特殊方法,他是解释器提供的.由双下划线+方法名+双下划线 .它具有特殊意义的方法,双下方法主要是python源码程序员使用的,我们在开发中尽量不要使用双下方法,但是深入研究双下方法,更 ...
随机推荐
- IO和流
I/O和流 I/O是Input和Output的缩写 从读写设备,包括硬盘文件,内存,键盘输入,屏幕输出,网路 输入输出"内容"(字节或文本) 流是对输入输出设备的一种抽象 从流中读 ...
- PHP 解决对文件操作的高并发问题
解决方案: 对文件进行加锁时,设置一个超时时间.超时设置为1ms,如果这段时间内没有获得锁,就反复获得,直到获得对文件的操作权为止.如果超市限制已到,就必须马上退出,让出锁让其他进程进行操作. ...
- python django 之 django自定制分页
自定制的分页模块 #!/usr/bin/env python3 # V1.1 解决问题: # 1). p 参数 为 负数 与 p 参数查过总页数时报错的问题 # V1.2 解决的问题: # 1). 点 ...
- jvm GC算法和种类
1.GC 垃圾收集 Garbage Collection 通常被称为“GC”,它诞生于1960年 MIT 的 Lisp 语言,经过半个多世纪,目前已经十分成熟了. jvm 中,程序计数器.虚拟 ...
- SpringBoot入门系列(三)资源文件属性配置
前面介绍了Spring的@Controller和@RestController控制器, 他们是如何响应客户端请求,如何返回json数据.不清楚的朋友可以看看之前的文章:https://www.cnbl ...
- Web图片资源的加载与渲染时机
此文研究页面中的图片资源的加载和渲染时机,使得我们能更好的管理图片资源,避免不必要的流量和提高用户体验. 浏览器的工作流程 要研究图片资源的加载和渲染,我们先要了解浏览器的工作原理.以Webkit引擎 ...
- 前端模板引擎doT.js的使用
前言 我们在做前端开发时,经常需要根据后台返回的json数据动态生成html并插入到页面中显示.最简单的方法就是通过jQuery去遍历数据拼接html,如以下: <script> var ...
- 我厌倦了 Redux,那就造个轮子 Rectx:第三集
仓库:215566435/rectx 前言 麻烦快去我的仓库里面喷: 老子学不动了,求不要更新. 呵呵,你没想到吧,这玩意儿竟然有第三集!我靠,我自己都没想到,让我们悄悄的回顾一下前两集完全没想到,竟 ...
- 基于springboot1.5.9整合shiro时出现静态文件找不到的问题
开门见山吧,上午对shiro进行整合了下,因为之前使用ssm框架对shiro框架整合过,所以觉得使用springboot再次对shiro框架进行整合也是没啥问题,但最后整合完之后,使用thymelea ...
- 微服务架构-Gradle下载安装配置教程
一.开发条件 JDK8下载地址:https://www.oracle.com/java/technologies/javase-jdk8-downloads.html Eclipse下载地址:http ...