魔法方法之__getattr__(), __setattr__(), 和 __delattr__
1.python基础之注释2.python语言学习路线(基础)3.python源码结构4.python发展史及python应用场景5.变量6.bug及debug7.常见数据类型及其转换8.字符串格式化9.转义符10.字符串在货币、日期、精度的处理11.字符编解码12.字符编解码及其相互转换13.内置函数-help-帮助文档14.内置函数print-输出15.内置函数input16.运算符17.int的缓存策略(特别容易混)18.判断语句19.random模块20.判断语句+ random的应用-剪刀石头布游戏21.三元运算符(if else的简写)22.循环语句-while23.循环语句-while-练习题24.循环语句for循环25.循环语句 + else26.字符串类str27.正则在字符串中的简单应用28.列表(List)29.列表list的sort方法的坑30.列表综合应用-8个教室随机分配到3个教室31.元组32.自动组包 & 自动解包33.字典34.集合35.公共操作36.公共操作-推导式(集合、列表、字典)37.函数定义、调用、闭包38.拆包和交换变量值39.函数的变量作用域、返回值、参数40.函数递归41.匿名函数(lambda表达式)0142.内置函数abs43.内置函数round44.内置函数abs0245.高阶函数46.内置高阶函数map47.内置高阶函数reduce48.内置函数reduce49.学生管理系统-函数&循环&运算符综合练习50.文件操作之语法51.文件操作2-最佳实践52.文件操作之seek53.文件及文件夹操作54.面向对象基本概念55.面向对象之类、对象的定义56.添加和获取对象属性57.面向对象之魔法方法58.魔法函数 __repr__() 和 __str__()的区别59.魔法方法__len__60.魔法方法之__getitem__(self, key)、__setitem__(self, key, value) 和 __delitem__(self, key) 61.魔法方法之__iter__(self) && __next__(self)62.TypeError: iter() returned non-iterator of type 'MyIterable'63.魔法方法之__contains__()64.魔法方法之__call__
65.魔法方法之__getattr__(), __setattr__(), 和 __delattr__
66.__eq__(), __lt__(), 和 __gt__() 67.案例:烤地瓜68.案例:给房子置办家具69.继承70.继承之子类复用父类的属性、方法71.继承的分类72.MRO73.继承之子类重写父类同名属性和方法74.⼦类调⽤⽗类的同名⽅法和属性75.私有属性&&方法的定义&访问限制76.setter&getter方法访问私有属性77.__mro__属性78.python 面向对象3大特征详解79. 类属性和实例属性80.类属性和实例属性最佳实践81.类方法82.静态方法83.异常基础84.多组异常处理基础85.多组异常处理86.使用Python内置的错误信息87.捕获所有异常88.手动抛异常(raise)89.try-except-else-finally90.断言assert在异常中应用91.自定义异常类92.模块93.常见的5种模块导入94.模块的定位顺序95.__all__变量限制、明确导入范围96.包97.时间模块datetime98.多任务编程之并发、并行概念99.进程实现多任务(进程概念、单进程、多进程执行多任务)__getattr__ 当访问对象的属性不存在时被自动调用。
1 class MyObject: 2 def __init__(self): 3 self.data = {'name': 'Alice', 'age': 25} 4 self.id=1 5 6 def __getattr__(self, name): 7 print('__getattr__方法被自动调用') 8 if name in self.data: 9 return self.data[name] 10 else: 11 raise AttributeError(f"'MyObject' object has no attribute '{name}'") 12 13 obj = MyObject() 14 print(obj.id) # id属性存在,不会调用__getattr__方法 15 16 print(obj.name) # 输出:Alice 17 print(obj.age) # 输出:25 18 print(obj.gender) # 抛出 AttributeError 异常
__getattr__(), __setattr__(), 和 __delattr__()
1 ''' 2 __getattr__(), __setattr__(), 和 __delattr__() 都是 Python 的特殊方法,用于处理对象属性的访问、赋值和删除操作。 3 1. __getattr__(self, name): 4 1. 当访问一个不存在的属性时被调用。 5 2. 接受一个参数 name,表示要获取的属性名。 6 3. 可以通过该方法动态返回属性的值或抛出 AttributeError 异常。 7 8 2. __setattr__(self, name, value): 9 1. 当给对象的属性赋值时被调用。 10 2. 接受两个参数 name 和 value,分别表示属性名和要设置的值。 11 3. 可以在该方法中自定义属性赋值的行为,例如进行类型检查或触发其他操作。 12 13 3. __delattr__(self, name): 14 1. 当删除对象的属性时被调用。 15 2. 接受一个参数 name,表示要删除的属性名。 16 3. 可以在该方法中自定义属性删除的行为,例如执行一些清理操作或阻止删除某些属性。 17 18 最佳实践: 19 1. 使用 __getattr__() 方法可以实现延迟加载(lazy loading)或动态属性的功能。 20 2. 在 __setattr__() 方法中,要注意避免无限递归的问题。最好使用基类的 __setattr__() 方法来设置属性值。 21 3. 在 __delattr__() 方法中,要小心处理删除属性的逻辑,确保不会产生错误或导致对象状态不一致。 22 ''' 23 24 class MyObject: 25 def __init__(self): 26 self.data = {'name': 'Alice', 'age': 25} 27 28 def __getattr__(self, name): 29 print(f'__getattr__自动调用,name={name}') 30 if name in self.data: 31 return self.data[name] 32 else: 33 raise AttributeError(f"'MyObject' object has no attribute '{name}'") 34 35 def __setattr__(self, name, value): 36 print(f'__setattr__自动调用,name={name},value={value}') 37 if name == 'data': 38 super().__setattr__(name, value) 39 else: 40 self.data[name] = value 41 42 def __delattr__(self, name): 43 print(f'__delattr__自动调用,name={name}') 44 if name == 'data': 45 super().__delattr__(name) 46 else: 47 del self.data[name] 48 49 obj = MyObject() 50 51 # 获取属性 52 print(obj.name) # 输出:Alice 53 obj.id=1 54 print(obj.id) 55 56 # 设置属性 57 obj.age = 30 58 print(obj.age) # 输出:30 59 60 # 删除属性 61 del obj.name 62 print(obj.name) # 抛出 AttributeError 异常
执行结果:
__setattr__自动调用,name = data,value = { 'name' : 'Alice' , 'age' : 25 } __getattr__自动调用,name = name Alice __setattr__自动调用,name = id ,value = 1 __getattr__自动调用,name = id 1 __setattr__自动调用,name = age,value = 30 __getattr__自动调用,name = age 30 __delattr__自动调用,name = name __getattr__自动调用,name = name Traceback (most recent call last): File "F:\allen_class\python\base\034魔法方法之__getattr__&&__setattr__&&__delattr__.py" , line 62 , in <module> print (obj.name) # 抛出 AttributeError 异常 ^^^^^^^^ File "F:\allen_class\python\base\034魔法方法之__getattr__&&__setattr__&&__delattr__.py" , line 33 , in __getattr__ raise AttributeError(f "'MyObject' object has no attribute '{name}'" ) AttributeError: 'MyObject' object has no attribute 'name' |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!