面向对象编程:圆形类

1 投票
2 回答
2263 浏览
提问于 2025-04-18 05:19

我正在用Python写一个叫做Circle的类。现在我想在这个类里面定义一些方法,所以我这样做了。但是当我运行程序的时候,它崩溃了,并提示这些方法没有定义。我找不到问题出在哪里。

class Circle():
""" Holds data on a circle in the plane """
    def __init__(self,*args):
        if isinstance(args[0],Point) and isinstance(args[1],(float,int)):
            assert args[1]>0
            self.center= args[0]
            self.r= args[1]

        else:
            assert args[2]>0
            self.a=args[0]
            self.b=args[1]
            self.center= Point(self.a,self.b)
            self.r= args[2]
     def __mul__(self,other):
         assert isinstance(other,(float,int))
         assert other>0
         return Circle(self.center,self.r*other)

     __rmul__= __mul__
    def area(self):
        return math.pi*self.r**2

    def circumference(self):
        return 2*self.r*math.pi

    def move(self,p):
        assert isinstance(p,Point)
        self.center= p
        return None

我也写了一个Point的类,所以这不是问题所在。当我运行程序时,发生了这样的事情:

>>> a=Circle(-3,-3,1)
>>> area(a)
Traceback (most recent call last):
File "<pyshell#4>", line 1, in <module>
area(a)
NameError: name 'area' is not defined

2 个回答

0

类里面的方法是可以被实例使用的,但你得用“.”这个符号来调用它们。

所以,在你的例子中,你应该使用

a = Circle()
a.area()

而不是

area(a)
1

编辑: 正如@jsbueno所指出的,这并不是导致你错误信息的原因:你的缩进不对(def __mul__ 应该向左缩进一个空格),所以Python认为你已经结束了类的定义,而只是定义了一些普通的函数(而不是类的方法)。

另外,你应该把area当作一个方法来调用 - 用a.area(),而不是area(a)

我对代码做了一些调整 - 添加了一些注释,重命名了一些变量,整体上进行了清理 - 现在这段代码可以正常工作了:

from math import pi

class Point:
    def __init__(self, x, y):
        self.x = x
        self.y = y

class Circle:
    """
    Holds data on a circle in the plane
    """
    def __init__(self, a, b, c=None):
        if c is None:
            # Circle(Point, scalar)
            self.center = a
            self.r = b
        else:
            # Circle(scalar, scalar, scalar)
            self.center = Point(a, b)
            self.r = c

    @property
    def r(self):
        return self._r

    @r.setter
    def r(self, new_r):
        assert new_r > 0
        self._r = new_r

    def __mul__(self, scale_by):
        return Circle(self.center, self.r * scale_by)

    __rmul__ = __mul__

    def area(self):
        return pi * self.r**2

    def circumference(self):
        return 2 * pi * self.r

    def move(self, new_center):
        self.center = new_center

然后

a = Circle(-3,-3,1)
print(a.area())

给出

3.141592653589793

这是正确的。

撰写回答