I am trying to create a cutom 'Float' type using built in 'float' type. Here is the code:

class Attribute(object):
    Common attributes and methods for custom types
    def __init__(self, name=None, type=None, range=None):
        self.__name = name
        self.__type = type
        self.__range = range
    #Read only attributes
    name = property(lambda self: self.__name)
    type = property(lambda self: self.__type)
    range = property(lambda self: self.__range)

class Float(float, Attribute):
    '''Custom Float type'''
    __slots__ = ('__name', '__type', '__range')
    def __init__(self, value=0.0, name=None, type=None, range=(0.0, 1.0)):
            super(Float, self).__init__(name=name, type=type, range=range)
            float.__init__(self, value)
            print 'Error : %s %s' % sys.exc_info()[:2]

a = Float(2.0, name='myFloat')

The problem is, I am not able to pass arguments when creating an instance. How do I solve this?

I would probably take a completely different approach:

class MyFloat(float):

    def __new__(self, name, value):
        return float.__new__(self, value)

    def __init__(self, name, value):
        self._name = name

    name = property(lambda self: self._name)
x=MyFloat("name", 1.5)
print x
print x._name
print x.name

The call to __new__ is necessary when subclassing immutable types like float -- the call order is __new__, followed by __init__ on initialization, and all of the arguments are passed to both.


Be a part of the DaniWeb community

We're a friendly, industry-focused community of 1.20 million developers, IT pros, digital marketers, and technology enthusiasts learning and sharing knowledge.