鱼C论坛

 找回密码
 立即注册
查看: 2992|回复: 5

[已解决]课后题50讲动手提

[复制链接]
发表于 2020-3-3 16:40:13 | 显示全部楼层 |阅读模式

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

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

x
问大家一个问题:Python 支持常量吗?相信很多鱼油的答案都是否定的,但实际上 Python 内建的命名空间是支持一小部分常量的,比如我们熟悉的 True,False,None 等,只是 Python 没有提供定义常量的直接方式而已。那么这一题的要求是创建一个 const 模块,功能是让 Python 支持常量。
我的程序是:
  1. class Const:
  2.     def __init__(self):
  3.         self.name_list = []

  4.     def __getattr__(self,name):
  5.         print("常量不存在!")

  6.     def __setattr__(self,name,value):
  7.         if name.isupper():
  8.             if name not in self.name_list:
  9.                 self.name = value
  10.                 self.name_list.append(name)
  11.             else:
  12.                 raise TypeError("常量无法修改!")
  13.         else:
  14.             raise TypeError("常量名需要大写")

  15. import sys
  16. sys.modules[__name__] = Const()
  17.             
复制代码


为什么经过下面程序输出不对呢?
  1. import const


  2. const.NAME = "FishC"
  3. print(const.NAME)

  4. try:
  5.     const.NAME = "FishC.com"
  6. except TypeError as Err:
  7.     print(Err)

  8. try:
  9.     const.name = "FishC"
  10. except TypeError as Err:
  11.     print(Err)
复制代码


最终想要的结果是:
  1. >>>
  2. FishC
  3. 常量无法改变!
  4. 常量名必须由大写字母组成!
复制代码

最佳答案
2020-3-3 17:20:18
zhouxinxing 发表于 2020-3-3 17:12
给您说一下我这个思路就是先判断是不是名字是大写的,如果不是就返回raise TypeError("常量名需要大写") ...

self.name = value 不仅会递归调用,而且变量名不是大写("name" 不是大写)
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-3 17:04:25 | 显示全部楼层
感觉你的思路是错的。参考一下下面的代码:

  1. class Const:
  2.     def __setattr__(self, name, value):
  3.         if name in self.__dict__:    # 变量已经定义过
  4.             raise TypeError("常量无法修改")
  5.         elif name.isupper():
  6.             super().__setattr__(name, value)
  7.         else:
  8.             raise TypeError("常量名需要大写")


  9. import sys
  10. sys.modules[__name__] = Const()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-3 17:12:43 | 显示全部楼层
zltzlt 发表于 2020-3-3 17:04
感觉你的思路是错的。参考一下下面的代码:

给您说一下我这个思路就是先判断是不是名字是大写的,如果不是就返回raise TypeError("常量名需要大写"),
然后如果名字是大写的就判断名字是否出现在列表中,如果没出现就self.name = value,然后把名字添加到列表中,如果出现了就返回raise TypeError("常量无法修改!"),不知道这样想错在了什么地方,有点想不明白,请您指教~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-3 17:20:18 | 显示全部楼层    本楼为最佳答案   
zhouxinxing 发表于 2020-3-3 17:12
给您说一下我这个思路就是先判断是不是名字是大写的,如果不是就返回raise TypeError("常量名需要大写") ...

self.name = value 不仅会递归调用,而且变量名不是大写("name" 不是大写)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-3-3 17:20:38 | 显示全部楼层
zhouxinxing 发表于 2020-3-3 17:12
给您说一下我这个思路就是先判断是不是名字是大写的,如果不是就返回raise TypeError("常量名需要大写") ...

另外不需要对 __getattr__ 进行重写。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-3 17:36:26 | 显示全部楼层
zltzlt 发表于 2020-3-3 17:20
self.name = value 不仅会递归调用,而且变量名不是大写("name" 不是大写)

对对,self.name = value确实会递归调用了,谢谢您~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-1 11:53

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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