Как обрабатывать целое число как массив байтов в Python?

Я пытаюсь декодировать результат функции Python os.wait(). Это возвращает, согласно документам Python:

кортеж, содержащий его индикацию состояния pid и выхода: 16-разрядное число, младший байт которого является номером сигнала, который убил процесс, и чей старший байт является статусом выхода (если номер сигнала равен нулю); старший бит младшего байта устанавливается, если был создан основной файл.

Как декодировать индикацию состояния выхода (которая является целым числом), чтобы получить высокий и низкий байт? Чтобы быть конкретным, как реализовать функцию декодирования, используемую в следующем фрагменте кода:

(pid,status) = os.wait()
(exitstatus, signum) = decode(status) 

Ответ 1

Это сделает то, что вы хотите:

signum = status & 0xff
exitstatus = (status & 0xff00) >> 8

Ответ 2

Чтобы ответить на ваш общий вопрос, вы можете использовать методы бит-манипуляции:

pid, status = os.wait()
exitstatus, signum = status & 0xFF, (status & 0xFF00) >> 8

Однако для интерпретации значений статуса выхода есть встроенные функции:

pid, status = os.wait()
exitstatus, signum = os.WEXITSTATUS( status ), os.WTERMSIG( status )

См. также:

  • os.WCOREDUMP()
  • os.WIFCONTINUED()
  • os.WIFSTOPPED()
  • os.WIFSIGNALED()
  • os.WIFEXITED()
  • os.WSTOPSIG()

Ответ 3

Вы можете разбить свой int на строку беззнаковых байтов с помощью struct:

import struct
i = 3235830701  # 0xC0DEDBAD
s = struct.pack(">L", i)  # ">" = Big-endian, "<" = Little-endian
print s         # '\xc0\xde\xdb\xad'
print s[0]      # '\xc0'
print ord(s[0]) # 192 (which is 0xC0)

Если вы соедините это с array, вы можете сделать это более удобно:

import struct
i = 3235830701  # 0xC0DEDBAD
s = struct.pack(">L", i)  # ">" = Big-endian, "<" = Little-endian

import array
a = array.array("B")  # B: Unsigned bytes
a.fromstring(s)
print a   # array('B', [192, 222, 219, 173])

Ответ 4

exitstatus, signum= divmod(status, 256)

Ответ 5

Вы можете распаковать статус, используя бит-сдвиг и маскировка.

low = status & 0x00FF
high = (status & 0xFF00) >> 8

Я не программист на Python, поэтому надеюсь, что синтаксис правильный.

Ответ 6

Люди до меня прибили его, но если вы действительно хотите его на одной строке, вы можете сделать это:

(signum, exitstatus) = (status & 0xFF, (status >> 8) & 0xFF)

РЕДАКТИРОВАТЬ: Если бы он был назад.