Binary Decimals in Python
Grant Olson
kgo at grant-olson.net
Tue Mar 30 11:35:21 EDT 2010
On 3/30/2010 11:13 AM, aditya wrote:
> To get the decimal representation of a binary number, I can just do
> this:
>
> int('11',2) # returns 3
>
> But decimal binary numbers throw a ValueError:
>
> int('1.1',2) # should return 1.5, throws error instead.
>
> Is this by design? It seems to me that this is not the correct
> behavior.
>
Well technically that would be a 'radix point', not a decimal point.
But I think the problem is that computers don't store fractional values
that way internally. They either use floating or fixed point math. You
would never look at raw binary data on a computer and see something like
'1010.1010', and no one would write it that way, and no language (that I
know of) would accept that as a valid value if you did something like "x
= 0b1010.1010"
So in that sense, it might not be an intentional oversight, but it's not
a very practical or useful feature.
More information about the Python-list
mailing list