Su Python 2.5 Ho bisogno di usare numeri float con un metodo modificato __str__()
. Inoltre ho bisogno di sapere quando il costruttore fallisce.Sottoclasse di tipo float in Python, non riesce a rilevare l'eccezione in __init __()
Perché non riesco a rilevare le eccezioni sollevate da float.__init__()
?
Qual è il modo migliore per consultare il valore numerico del mio oggetto float derivato? Nel mio codice sto usando float(self)
.
class My_Number(float):
def __init__(self, float_string):
try:
super(My_Number, self).__init__(float_string)
except (TypeError, ValueError):
raise My_Error(float_string)
def __str__(self):
if int(float(self)) == float(self):
return str(int(float(self)))
else:
return str(round(float(self), 2))
>>> n = My_Number('0.54353')
>>> print n
0.54
>>> n = My_Number('5.0')
>>> print n
5
>>> n = My_Number('foo')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for float(): foo
Funziona !, grazie per la spiegazione. – Ricardo