Python子类

use*_*517 3 python class

我有这个类与分数一起工作(例如(1,2),(3,4)等):

class Fraction(object):

    def __init__(self, num=0, denom=1):
        ''' Creates a new Fraction with numberator num and denominator denom'''
        self.numerator = num
        if denom != 0:
            self.denominator = denom
        else: 
            raise ZeroDivisionError
    def __str__(self):
        '''Returns the string numerator/denominator '''
        return "{0}/{1}".format(self.numerator, self.denominator)
    def __repr__(self):
        """blah"""
        return Fraction(self.numerator, self.denominator)
Run Code Online (Sandbox Code Playgroud)

我希望有一个子类混合数,它可以接受整数和分数(例如2分数(1,2),3分数(3,4)等).我不知道如何做到这一点,任何有关如何做到这一点的帮助将不胜感激

class MixedNumber(Fraction):
Run Code Online (Sandbox Code Playgroud)

mta*_*add 5

在考虑MixedNumber使用提供的Fraction类实现类时,有两种方法可以立即浮现在脑海中.正如@HunterMcMillen建议的那样,一种方法是使用类使用组合,即利用不同的对象分别表示整数和分数部分.这使您可以访问类中的每个对象专用方法,如果您构建的组件具有每个封装的不同行为,则可以很方便.

class MixedNumber(object):
   def __init__(self, whole_number, fraction):
        self.whole_number = whole_number
        self.fraction = fraction

   def __str__(self):
        if self.fraction.numerator == 0:
            return str(self.whole_number)
        elif self.whole_number == 0:
            return str(self.fraction)
        else:
            return '{} {}'.format(self.whole_number,self.fraction)

   def __repr__(self):
        return 'MixedNumber({},{!r})'.format(self.whole_number,self.fraction)
Run Code Online (Sandbox Code Playgroud)

另一种可能是继承,如果你的Fraction类支持不正确的分数,那么你可以使用子类以混合数字格式适当地处理初始化和字符串渲染,如下所示:

class MixedNumber(Fraction):
    def __init__(self, whole_number, fraction):     
        num = whole_number * fraction.denominator + fraction.numerator
        super(MixedNumber,self).__init__(num,  fraction.denominator)

    def __str__(self):
        # assume positive fractions for demonstration only
        q, r = divmod(self.numerator,self.denominator)
        if r == 0:
            return str(q)
        elif q == 0:
            return super(MixedNumber,self).__str__() 
        else:
            return '{} {}/{}'.format(q,r,self.denominator)

    def __repr__(self):
        q, r = divmod(self.numerator, self.denominator)
        return 'MixedNumber({},Fraction({},{}))'.format(q,r,self.denominator)
Run Code Online (Sandbox Code Playgroud)

你的Fraction.__repr__方法应该返回一个字符串,当传入时eval应该实例化与源对象相等的东西,即eval(frac) == frac.有关和之间区别的更多详细信息,请参阅此堆栈溢出问题.__str____eval__