it-swarm.com.ru

Типирование в Python

Мне нужно преобразовать строки в Python в другие типы, такие как 8-разрядные, 8-разрядные, 32-разрядные и 64-разрядные целые числа без знака и со знаком, двойные числа, числа с плавающей запятой и строки.

Как я могу это сделать?

19
user46646

Вы можете преобразовать строку в 32-разрядное целое число со знаком с помощью функции int:

str = "1234"
i = int(str)  // i is a 32-bit integer

Если строка не представляет целое число, вы получите исключение ValueError. Обратите внимание, однако, что если строка действительно представляет целое число, но это целое число не помещается в 32-разрядное целое число со знаком, то вместо этого вы получите объект типа long.

Затем вы можете преобразовать его в другие значения ширины и подписи с помощью простой математики:

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

Вы можете преобразовать строки в число с плавающей запятой с помощью функции float:

f = float("3.14159")

Плавания Python - это то, что другие языки называют double, то есть они 64-битные. В Python нет 32-битных операций с плавающей запятой.

36
Adam Rosenfield

Следующие типы - по большей части - вообще не существуют в Python. В Python строки преобразуются в int, long или float, потому что это все, что есть.

Вы запрашиваете конверсии, которые не имеют отношения к Python. Вот список типов, которые вы просили, и их эквивалент Python.

  • без знака и со знаком int 8 бит, int
  • без знака и со знаком int 16 бит, int
  • 32-разрядные без знака и со знаком, без знака: long , со знаком int
  • без знака и со знаком int 64 бита, long

  • двойной, плавать

  • плавать, плавать
  • строка, это то, что вы должны были начать с

Я не знаю, каковы следующие, поэтому я не знаю эквивалент Python.

  • без знака и со знаком 8 бит, 
  • без знака и подписи 16 бит, 
  • без знака и подписи 32 бит,
  • без знака и подписи 64 бит.

У вас уже есть все важные преобразования: int(), long() и float().

3
S.Lott

Python имеет только один тип int. Чтобы преобразовать строку в int, используйте int(), например так:

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

Правка: Также для преобразования в число с плавающей запятой, используйте float() точно таким же образом.

2
Jeremy Ruten

У меня только сейчас была проблема, когда мне передавали значение в виде 16-битного числа с добавлением в двойную подпись от Modbus . Мне нужно было преобразовать это в число со знаком .. Я закончил писать это, что, кажется, работает нормально ,.

# 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
0
user50619

Я не думаю, что на это можно обязательно ответить хорошо без дополнительной информации. Как уже говорили другие, в python есть только целые и длинные целые числа - язык не придерживается архетипов битовой ширины и сигнатуры языков программирования более низкого уровня.

Если вы работаете полностью в Python, то вы, вероятно, задаете не тот вопрос. Вероятно, есть лучший способ сделать то, что вам нужно.

Если вы взаимодействуете, например, с кодом C или по сети, то есть есть способы сделать это, и похоже, что ответ на вашу предыдущую публикацию довольно легко охватил этот путь.

0
Jorenko