python - 如何处理 python 对象创建过程中的错误

标签 python python-3.x fractions

我正在尝试编写一个类来帮助我输出带分数。

这段代码很适合我的目的

class mixed_fraction():
    from fractions import Fraction
    '''Returns mixed fractions in tuple format
    (whole_part, numerator, denominator)
    '''
    def __init__(self, numerator = 0, denominator = 1):
        self.numerator = numerator
        self.denominator = denominator
    def mixed(self):
        if self.denominator == 0:
            return 'Denominator cannot be Zero'
        quotient = int(self.numerator/self.denominator)
        remain = self.numerator - (self.denominator * quotient)
        frac = Fraction(remain, self.denominator)
        return (quotient, frac.numerator, frac.denominator)

示例输入

print(mixed_fraction(3, 2).mixed())
print(mixed_fraction(1, 5).mixed())
print(mixed_fraction(1, 0).mixed())
print(mixed_fraction().mixed())
print(mixed_fraction(7, 2).mixed())
print(mixed_fraction(769, 17).mixed())
print(mixed_fraction(384, 256).mixed())

输出

(1, 1, 2)
(0, 1, 5)
Denominator cannot be Zero
(0, 0, 1)
(3, 1, 2)
(45, 4, 17)
(1, 1, 2)

但我希望能够在创建对象时指出零错误,因为首先创建一个零除数的分数是没有意义的。所以我需要帮助来及时发现错误。

class mixed_fraction():
    from fractions import Fraction
    '''Returns mixed fractions in tuple format
    (whole_part, numerator, denominator)
    '''
    def __init__(self, numerator = 0, denominator = 1):
        self.numerator = numerator
        self.denominator = denominator
        if denominator == 0:
            return 'Denominator cannot be Zero'
    def mixed(self):
        quotient = int(self.numerator/self.denominator)
        remain = self.numerator - (self.denominator * quotient)
        frac = Fraction(remain, self.denominator)
        return (quotient, frac.numerator, frac.denominator)

问题是 __init__ 必须返回 None。所以我不知道如何解决这个问题

最佳答案

当您想在 Python 中生成错误时,您不会返回值:您会引发错误。

在这种情况下,最合适的是 ZeroDivisionError:

def __init__(self, numerator = 0, denominator = 1):
    self.numerator = numerator
    self.denominator = denominator
    if denominator == 0:
        raise ZeroDivisionError('Denominator cannot be Zero!')

ZeroDivisionError 本身是“ArithmeticError”的特化 - 但您可以通过对其进行子类化来根据您的目的进一步定制错误:

class ZeroDenominatorError(ZeroDivisionError): 
    pass

它的主要优点是程序流程可以层层下降 没有使用 try...except block 正确处理错误的代码 - 直到你捕获它的地方 - 否则你必须放置一个 if 语句在您实例化类的所有地方检查返回值的类型。

所以 - 这是处理它的正确方法。现在,根据设计,可能希望类的实例化失败并返回另一个值(“无”比错误消息更好 - 有错误,只需引发异常)。在这种情况下,您应该编写 __new__ 方法而不是 __init__。与 __init__ 不同,它必须返回新创建的实例。 (而且它还必须通过正确调用父类(super class)的 __new__ 方法来创建那个新实例):

from fractions import Fraction

class MixedFraction(Fraction):
    def __new__(cls, numerator=0, denominator=1):
        if not denominator:
            return None
        instance = super().__new__(cls, numerator, denominator)
        return instance
    def mixed(self):
        quotient = self.numerator // self.denominator
        remain = self.numerator - (self.denominator * quotient)
        return (quotient, remain, self.denominator)

至于 Hilliad 在他的回答中的建议,这直接继承自“Fraction”——这意味着它可以在任何使用 Fraction 的地方使用,但它有额外的“混合”方法。请注意,如果您无论如何都在操作分子和分母参数,那么从 Fraction 继承将需要您编写 __new__ 而不是 __init__:它们是在实例化时在对象中设置的, 在 native (C) 代码中,不能进一步更改。

关于python - 如何处理 python 对象创建过程中的错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43230292/

相关文章:

Python: map 类在静态范围内的功能

python - 取列表列表的平均值,忽略零值

java - 我如何进行像 5' 3"1/2 这样的测量,然后将其乘以 1.414 并在 android java 上以相同的格式显示答案

java - 在 java 中将 double 分成两部分 "integer & fraction"的最佳方法是什么

javascript - 使用前端 javascript 访问绑定(bind)到 Bokeh 字形的数据

python - Txredisapi异常.RuntimeError : maximum recursion depth exceeded

python - ubuntu filedialog.askdirectory 版本太低

python - 什么是 tensorflow.compat.as_str()?

python-3.x - pip vs python -m pip 为什么 pip 命令抛出模块对象不可调用错误

r - 是否可以评估指数的分数与指数之和