Подтвердить что ты не робот

RGB Int в RGB - Python

Как преобразовать целое число RGB в соответствующий RGB кортеж (R,G,B)? Кажется достаточно простым, но я ничего не могу найти в Google.

Я знаю, что для каждого RGB (R,G,B) у вас есть целое число n = r256^2 + g256 + b, как я могу решить обратное в Python, IE с учетом n, мне нужны r, g, b значения.

4b9b3361

Ответ 1

Я вообще не эксперт Python, но насколько я знаю, он имеет те же операторы, что и C.

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

Blue =  RGBint & 255
Green = (RGBint >> 8) & 255
Red =   (RGBint >> 16) & 255

Что он делает, чтобы маскировать младший байт в каждом случае (двоичный и с 255.. равно 8 бит). Для зеленого и красного компонентов он делает то же самое, но сначала переключает цветной канал на младший байт.

Ответ 2

Из целого числа RGB:

Blue =  RGBint mod 256
Green = RGBint / 256 mod 256
Red =   RGBint / 256 / 256 mod 256

Это может быть довольно просто реализовано, как только вы знаете, как его получить.:)

Обновление: добавлена ​​функция python. Не уверен, есть ли лучший способ сделать это, но это работает на Python 3 и 2.4

def rgb_int2tuple(rgbint):
    return (rgbint // 256 // 256 % 256, rgbint // 256 % 256, rgbint % 256)

Там также отличное решение, которое использует битхиттинг и маскировку, что, несомненно, намного быстрее, чем опубликовал Нильс Пипренбринк.

Ответ 3

>>> import struct
>>> str='aabbcc'
>>> struct.unpack('BBB',str.decode('hex'))
(170, 187, 204)

for python3:
>>> struct.unpack('BBB', bytes.fromhex(str))

и

>>> rgb = (50,100,150)
>>> struct.pack('BBB',*rgb).encode('hex')
'326496'

for python3:
>>> bytes.hex(struct.pack('BBB',*rgb))

Ответ 4

Я предполагаю, что у вас есть 32-разрядное целое число, содержащее значения RGB (например, ARGB). Затем вы можете распаковать двоичные данные с помощью модуля struct:

# Create an example value (this represents your 32-bit input integer in this example).
# The following line results in exampleRgbValue = binary 0x00FF77F0 (big endian)
exampleRgbValue = struct.pack(">I", 0x00FF77F0)

# Unpack the value (result is: a = 0, r = 255, g = 119, b = 240)
a, r, g, b = struct.unpack("BBBB", exampleRgbValue)

Ответ 5

>>> r, g, b = (111, 121, 131)
>>> packed = int('%02x%02x%02x' % (r, g, b), 16)

В результате получается следующее целое число:

>>> packed
7305603

Затем вы можете распаковать его либо длинным явным способом:

>>> packed % 256
255
>>> (packed / 256) % 256
131
>>> (packed / 256 / 256) % 256
121
>>> (packed / 256 / 256 / 256) % 256
111

.. или более компактным образом:

>>> b, g, r = [(packed >> (8*i)) & 255 for i in range(3)]
>>> r, g, b

Образец применяется с любым количеством цифр, например, цветом RGBA:

>>> packed = int('%02x%02x%02x%02x' % (111, 121, 131, 141), 16)
>>> [(packed >> (8*i)) & 255 for i in range(4)]
[141, 131, 121, 111]

Ответ 6

Просто примечание для тех, кто использует API приложений Google Appengine Images Python. Я обнаружил, что у меня была ситуация, когда мне приходилось подавать метод с 32-битным значением цвета RGB.

В частности, если вы используете API для преобразования PNG (или любого изображения с прозрачными пикселями), вам необходимо предоставить метод execute_transforms аргументу с именем transparent_substitution_rgb, который должен быть 32-битным значением цвета RGB.

Заимствование из ответа dbr, я придумал метод, подобный этому:

def RGBTo32bitInt(r, g, b):
  return int('%02x%02x%02x' % (r, g, b), 16)

transformed_image = image.execute_transforms(output_encoding=images.JPEG, transparent_substitution_rgb=RGBTo32bitInt(255, 127, 0))

Ответ 7

def unpack2rgb(intcol):
    tmp, blue= divmod(intcol, 256)
    tmp, green= divmod(tmp, 256)
    alpha, red= divmod(tmp, 256)
    return alpha, red, green, blue

Если было принято только предложение divmod(value, (divider1, divider2, divider3…)), оно также упростило бы различные преобразования времени.

Ответ 8

Вероятно, более короткий способ сделать это:

dec=10490586
hex="%06x" % dec
r=hex[:2]
g=hex[2:4]
b=hex[4:6]
rgb=(r,g,b)

РЕДАКТИРОВАТЬ: это неправильно - дает ответ в Hex, OP хочет int. EDIT2: усовершенствованный, чтобы уменьшить несчастье и неудачу - необходимо "% 06x", чтобы шестнадцатеричный символ всегда показывался как шесть цифр [спасибо комментарию Питера Хансена].

Ответ 9

Если вы используете NumPy, и у вас есть массив RGBints, вы также можете просто изменить его dtype, чтобы извлечь красные, зеленые, синие и альфа-компоненты:

>>> type(rgbints)
numpy.ndarray
>>> rgbints.shape
(1024L, 768L)
>>> rgbints.dtype
dtype('int32')
>>> rgbints.dtype = dtype('4uint8')
>>> rgbints.shape
(1024L, 768L, 4L)
>>> rgbints.dtype
dtype('uint8')

Ответ 10

Добавление к тому, что упоминалось выше. Краткая альтернатива с одним лайнером.

# 2003199 or #E190FF is Dodger Blue.
tuple((2003199 >> Val) & 255 for Val in (16, 8, 0))
# (30, 144, 255)

И во избежание путаницы в будущем.

from collections import namedtuple
RGB = namedtuple('RGB', ('Red', 'Green', 'Blue'))
rgb_integer = 16766720  # Or #ffd700 is Gold.
# The unpacking asterisk prevents a TypeError caused by missing arguments.
RGB(*((rgb_integer >> Val) & 255 for Val in (16, 8, 0)))
# RGB(Red=255, Green=215, Blue=0)