【实例简介】使用colorsys 检测颜色RGB值判断 是否发霉
【实例截图】
【核心代码】
import colorsys
from PIL import Image
import time
beg = time.time()
def get_dominant_color(image):
#颜色模式转换,以便输出rgb颜色值
image = image.convert('RGBA')
#生成缩略图,减少计算量,减小cpu压力
image.thumbnail((200, 200))
max_score = None
dominant_color = None
for count, (r, g, b, a) in image.getcolors(image.size[0] * image.size[1]):
# 跳过纯黑色
if a == 0:
continue
saturation = colorsys.rgb_to_hsv(r / 255.0, g / 255.0, b / 255.0)[1]
y = min(abs(r * 2104 g * 4130 b * 802 4096 131072) >> 13, 235)
y = (y - 16.0) / (235 - 16)
# 忽略高亮色
if y > 0.9:
continue
score = (saturation 0.1) * count
#if score > max_score:
max_score = score
dominant_color = (r, g, b)
return dominant_color
shuchu = list (get_dominant_color(Image.open('P:\图片素材\黄色标本.jpg')))
r = shuchu[0]
g = shuchu[1]
b = shuchu[2]
if r<= 100:
if g <= 170:
print ("发霉")
else :
print("未发霉")
print (r)
print (g)
print (b)
print (shuchu)
end = time.time()
print("运行时间:",end - beg)