Похоже, webcolors позволит вам сделать это:
rgb_to_name (rgb_triplet, spec = 'css3')
Преобразовать три набора целых чисел, подходящих для использования в триплете цвета rgb (), в соответствующее ему нормализованное имя цвета, если такое имя существует; допустимые значения: html4, css2, css21 и css3, а по умолчанию - css3.
Пример:
>>> rgb_to_name((0, 0, 0))
'black'
наоборот:
>>> name_to_rgb('navy')
(0, 0, 128)
Чтобы найти ближайшее название цвета:
Однако webcolors
вызывает исключение, если не может найти соответствие для запрошенного цвета. Я написал небольшое исправление, обеспечивающее наиболее близкое имя для запрашиваемого цвета RGB. Соответствует евклидову расстоянию в пространстве RGB.
import webcolors
def closest_colour(requested_colour):
min_colours = {}
for key, name in webcolors.css3_hex_to_names.items():
r_c, g_c, b_c = webcolors.hex_to_rgb(key)
rd = (r_c - requested_colour[0]) ** 2
gd = (g_c - requested_colour[1]) ** 2
bd = (b_c - requested_colour[2]) ** 2
min_colours[(rd + gd + bd)] = name
return min_colours[min(min_colours.keys())]
def get_colour_name(requested_colour):
try:
closest_name = actual_name = webcolors.rgb_to_name(requested_colour)
except ValueError:
closest_name = closest_colour(requested_colour)
actual_name = None
return actual_name, closest_name
requested_colour = (119, 172, 152)
actual_name, closest_name = get_colour_name(requested_colour)
print "Actual colour name:", actual_name, ", closest colour name:", closest_name
Выход:
Actual colour name: None , closest colour name: cadetblue