我有一个用于处理基本几何特征(例如角度和正多边形)的模块。给我问题的部分在这里:
# geometry.py
_angle_mode = 'd'
@property
def angle_mode():
return _angle_mode
@angle_mode.setter
def angle_mode(value):
if value != 'd' or value != 'r':
raise ValueError("ValueError: invalid mode: '{0}'".format(mode))
_angle_mode = value
class angle:
def __init__(self, value, mode=None):
if mode is None:
mode = _angle_mode
if mode == 'd':
self.deg = value
self.rad = math.radians(value)
elif mode == 'r':
self.rad = value
self.deg = math.degrees(value)
else:
raise ValueError("ValueError: invalid mode: '{0}'".format(mode))
def __repr__(self):
if _angle_mode == 'd':
return 'angle({0}deg)'.format(self.deg)
elif _angle_mode == 'r':
print(7)
return 'angle({0}rad)'.format(self.rad)
我遇到的问题与angle_mode
属性有关。
我希望在口译员那里发生以下事情:
# interpreter
>>> import geometry
>>> a, b = geometry.angle(72), geometry.angle(2, 'r')
>>> a, b
(angle(72deg), angle(114.59...deg))
>>> geometry.angle_mode = 'r'
>>> a, b
(angle(1.25...rad), angle(2rad))
相反,a和b都将其值返回为geometry.angle_mode = 'r'
之前和之后的度数。如果直接设置geometry._angle_mode
,它可以正常工作,但是我想通过一个属性来获取/设置它,以便我可以强制执行这些模式。
为什么属性和.setter不能按预期工作,并且有什么解决办法?
编辑:
所建议的重复问题建议class classobject(object):...
,但随后继续在另一个类(而不是该类外部)中定义@classobject属性,并且不建议替换.setter。