鱼C论坛

 找回密码
 立即注册
查看: 2053|回复: 2

[已解决]求助:零基础入门学习python第50讲的习题

[复制链接]
发表于 2020-11-5 05:15:18 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我想请问下动动手习题我如此写为何报错?

class Const:
    def __init__(self):
        self.cons = {}

    def __setattr__(self, name, value):
        if name in self.cons:
            raise TypeError('常量无法改变!')

        if not name.isupper():
            raise TypeError('常量名必须由大写字母组成!')

        self.cons[name] = value


import sys

sys.modules[__name__] = Const()



报错的内容为:

Traceback (most recent call last):
  File "F:/Python练习/P050/constant.py", line 18, in <module>
    sys.modules[__name__] = Const()
  File "F:/Python练习/P050/constant.py", line 4, in __init__
    self.cons = {}
  File "F:/Python练习/P050/constant.py", line 7, in __setattr__
    if name in self.cons:
AttributeError: 'Const' object has no attribute 'cons'


提前感谢!
最佳答案
2020-11-5 10:51:23
本帖最后由 fall_bernana 于 2020-11-5 10:56 编辑

'''
你可以看你的错误。python的错误都是按运行的顺序报的。self.cons = {}后的一步是if name in self.cons:
所以说明当初始化的时候,self.cons ,对象调用cons 就会自动执行__setattr__方法,
然后__setattr__方法里面又是对象调用属性,而这个时候属性并没有建好。
为了避免这个问题需要用下面这种方式实现:
'''
def __init__(self):
        object.__setattr__(self,'cons',{})
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-11-5 10:51:23 | 显示全部楼层    本楼为最佳答案   
本帖最后由 fall_bernana 于 2020-11-5 10:56 编辑

'''
你可以看你的错误。python的错误都是按运行的顺序报的。self.cons = {}后的一步是if name in self.cons:
所以说明当初始化的时候,self.cons ,对象调用cons 就会自动执行__setattr__方法,
然后__setattr__方法里面又是对象调用属性,而这个时候属性并没有建好。
为了避免这个问题需要用下面这种方式实现:
'''
def __init__(self):
        object.__setattr__(self,'cons',{})
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-11-5 20:23:23 | 显示全部楼层
fall_bernana 发表于 2020-11-5 10:51
'''
你可以看你的错误。python的错误都是按运行的顺序报的。self.cons = {}后的一步是if name in self.con ...

啊,懂了!
非常感谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 00:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表