Typecasting in Python

Question:

I need to convert strings in Python to other types such as unsigned and signed 8, 16, 32, and 64 bit ints, doubles, floats, and strings.

How can I do this?

Asked By: user46646

||

Answers:

Python only has a single int type. To convert a string to an int, use int() like this:

>>> str = '123'
>>> num = int(str)
>>> num
123

Edit: Also to convert to float, use float() in the exact same way.

Answered By: Paige Ruten

You can convert a string to a 32-bit signed integer with the int function:

string = "1234"
i = int(string)  # i is a 32-bit integer

If the string does not represent an integer, you’ll get a ValueError exception. Note, however, that if the string does represent an integer, but that integer does not fit into a 32-bit signed int, then you’ll actually get an object of type long instead.

You can then convert it to other widths and signednesses with some simple math:

s8 = (i + 2**7) % 2**8 - 2**7      # convert to signed 8-bit
u8 = i % 2**8                      # convert to unsigned 8-bit
s16 = (i + 2**15) % 2**16 - 2**15  # convert to signed 16-bit
u16 = i % 2**16                    # convert to unsigned 16-bit
s32 = (i + 2**31) % 2**32 - 2**31  # convert to signed 32-bit
u32 = i % 2**32                    # convert to unsigned 32-bit
s64 = (i + 2**63) % 2**64 - 2**63  # convert to signed 64-bit
u64 = i % 2**64                    # convert to unsigned 64-bit

You can convert strings to floating point with the float function:

f = float("3.14159")

Python floats are what other languages refer to as double, i.e. they are 64-bits. There are no 32-bit floats in Python.

Answered By: Adam Rosenfield

The following types — for the most part — don’t exist in Python in the first place. In Python, strings are converted to ints, longs or floats, because that’s all there is.

You’re asking for conversions that aren’t relevant to Python in the first place. Here’s the list of types you asked for and their Python equivalent.

  • unsigned and signed int 8 bits, int
  • unsigned and signed int 16 bits, int
  • unsigned and signed int 32 bits, unsigned: long, signed int
  • unsigned and signed int 64 bits, long

  • double, float

  • float, float
  • string, this is what you had to begin with

I don’t know what the following are, so I don’t know a Python equivalent.

  • unsigned and signed 8 bit,
  • unsigned and signed 16 bit,
  • unsigned and signed 32 bit,
  • unsigned and signed 64 bit.

You already have all the conversions that matter: int(), long() and float().

Answered By: S.Lott

I don’t think this can necessarily be answered well without more information. As others have said, there are only int and long for integers in python — the language doesn’t adhere to the bit-width and signedness archetypes of lower-level programming languages.

If you’re operating completely within python, then you’re probably asking the wrong question. There’s likely a better way to do what you need.

If you are interoperating with, for instance, C code, or over the network, then there are ways to do this, and it looks like the answer to your previous posting covered that avenue pretty handily.

Answered By: Jorenko

I just now had a problem where I had a value passed as a 16 bit signed twos complement number from modbus.
I needed to convert this to a signed number.
I ended up writing this, which seems to work fine.

# convert a 32 bit (prob) integer as though it was 
# a 16 bit 2's complement signed one
def conv_s16(i):
    if (i & 0x8000):
        s16 = -(((~i) & 0xFFFF) + 1)
    else:
        s16 = i
    return s16
Answered By: user50619
Categories: questions Tags: , , , ,
Answers are sorted by their score. The answer accepted by the question owner as the best is marked with
at the top-right corner.