Nmbh 发表于 2020-6-10 14:20:15

定义类的方法时,怎么将类的属性作为默认参数传入方法?

《零基础入门学习Python》36课的课后题 动动手的题目1要求设计个长方形的类。
https://xxx.ilovefishc.com/forum/201406/16/1756460wj7tz55yvvzz578.png
其中有个setRect的方法,我想以setRect(length,width)的方式进行修改属性,且在用户只输入length的参数时而未输入width的参数时,width默认为之前设置的宽度。
但是我发现在def setRect(self, length = self.length, width = self.width):会出错,self.length和self.width不能传入括号内,有没有大神有改进方法?
class Rectangle:
    def __init__(self,length = 5,width = 4):
      self.length = length
      self.width = width
    def getRect(self):
      print('这个矩形的长为%.2f,宽为%.2f' % (self.length,self.width))
    def setRect(self, length = self.length, width = self.width):
      self.length = length
      self.width = width
    def getArea(self):
      area = self.length*self.width
      return area

Stubborn 发表于 2020-6-10 14:39:28

本帖最后由 Stubborn 于 2020-6-10 16:47 编辑

def setRect(self, length, width = None):
    if width is not None:
       self.width = width
       ....

Twilight6 发表于 2020-6-10 14:43:38

本帖最后由 Twilight6 于 2020-6-10 14:53 编辑

类属性是指 在类内方法之外的属性,带 self 的属性叫实例属性,而不是类属性

而你的例子 setRect(self, length = self.length, width = self.width) 先不说 实例属性到底在哪能用

就说你 self.length 前面完全没有定义也不能使用呀,类中的__init__方法就是为了让你初始化实例属性的

将类属性作为默认参数传入:
class Rectangle:
   
    _width = 4
    _length = 5
   
    def __init__(self,length = _length,width = _width):
      self.length = length
      self.width = width
    def getRect(self):
      print('这个矩形的长为%.2f,宽为%.2f' % (self.length,self.width))
    def setRect(self, length = _length, width = _width):
      self.length = length
      self.width = width
    def getArea(self):
      area = self.length*self.width
      return area

Nmbh 发表于 2020-6-10 18:03:10

Twilight6 发表于 2020-6-10 14:43
类属性是指 在类内方法之外的属性,带 self 的属性叫实例属性,而不是类属性

而你的例子 setRect(self,...

就按你这代码运行。按照下面步骤运行,width还是会在setRec()的时候重置成4,但我想要的是3
c = Rectangle(5,3)
c.setRect(5)
c.width
>>>4

Twilight6 发表于 2020-6-10 18:07:27

Nmbh 发表于 2020-6-10 18:03
就按你这代码运行。按照下面步骤运行,width还是会在setRec()的时候重置成4,但我想要的是3

你把上面改成 3 呀 ,程序不是那么死的东西
class Rectangle:
   
    _width = 3
    _length = 5
   
    def __init__(self,length = _length,width = _width):
      self.length = length
      self.width = width
    def getRect(self):
      print('这个矩形的长为%.2f,宽为%.2f' % (self.length,self.width))
    def setRect(self, length = _length, width = _width):
      self.length = length
      self.width = width
    def getArea(self):
      area = self.length*self.width
      return area

Nmbh 发表于 2020-6-10 18:12:50

通过改进成功实现
class Rectangle:
    def __init__(self,length = 5,width = 4):
      self.length = length
      self.width = width
    def getRect(self):
      print('这个矩形的长为%.2f,宽为%.2f' % (self.length,self.width))
    def setRect(self, length = None, width = None):
      if length == None:
            length = self.length
      if width == None:
            width = self.width
      self.length = length
      self.width = width
    def getArea(self):
      area = self.length*self.width
      return area
页: [1]
查看完整版本: 定义类的方法时,怎么将类的属性作为默认参数传入方法?