排序(十六进制)颜色以匹配彩虹

NFi*_*ano 5 python sorting algorithm colors

我有一个以十六进制表示的颜色列表 - 我需要对它们进行排序以匹配彩虹中的颜色顺序. - 我可以硬编码排序 - 但我觉得有一种更清洁的方式.

kin*_*all 12

这是一个函数,给定十六进制RGB的颜色规格,返回其HSV颜色:

import colorsys

def get_hsv(hexrgb):
    hexrgb = hexrgb.lstrip("#")   # in case you have Web color specs
    r, g, b = (int(hexrgb[i:i+2], 16) / 255.0 for i in xrange(0,5,2))
    return colorsys.rgb_to_hsv(r, g, b)
Run Code Online (Sandbox Code Playgroud)

现在您可以使用它来按色调对RGB十六进制颜色列表进行排序:

color_list = ["000050", "005000", "500000"]  # GBR
color_list.sort(key=get_hsv)
print color_list
Run Code Online (Sandbox Code Playgroud)

通过使用整个HSV元组进行排序,可以确保没有色调的颜色(即灰度)在一致的位置排序,并且具有相同色调但不同饱和度/值的颜色相对于其更饱和的/按照一致的顺序排序有价值的同行.

如果颜色因饱和度(强度)或值(亮度)而变化很大,你仍然会有一些混乱,但是没有解决这个问题.


Yan*_*min 5

查找HSV颜色表示:https://en.wikipedia.org/wiki/HSL_and_HSV

通过首先按顺序排序,您可以按感知颜色排序.您可以在RGB和HSV之间自由转换.