主頁 >  其他 > python可視化(4)色板(mpl.colors, colormap, plt.cm, palette)

python可視化(4)色板(mpl.colors, colormap, plt.cm, palette)

2020-09-16 15:18:38 其他

Excel中,顏色是通過界面展示及按鈕選擇確定的,在python代碼環境下,自然是沒有這種條件的,那么,matplotlib中顏色是如何構建與使用的呢?
matplotlib提供了強大的顏色介面,供使用者定制顏色、使用顏色、使用色板,主要包括以下幾個部分:
1、 matplotlib.colors 介面中定義的顏色空間,每一個顏色通過字典的形式進行保存,字典名為顏色名稱,字典值為顏色對應的RGB元組或十六進制字串,例如顏色名稱可以為 darkred,字典值為 #8B0000,凡是顏色命名空間中定義了的顏色,均可以通過顏色名字直接參考,
2、 命名空間解決了顏色怎么稱呼的問題,但并沒有建立好顏色與資料的映射關系,使用者往往希望序列(或資料)按照指定的顏色規則自動賦值,比如,我們希望較小的值被賦值為藍色,中間大小的值被賦值為白色,較大的值被賦值為黑色,但我們不可能為每一個數值一一指定顏色(1000個不唯一資料指定1000種顏色的難度可想而知),為此,開發者提出了色板colormap,通過plt.cm介面實作,主要通過兩種原理:一種是指定有限的N種顏色,回圈使用;另一種是將顏色映射到一個線性空間,將最大和最小的數值與顏色空間的兩端做對應,中間的資料采取差值的方法計算與之相對應的顏色,
本文將對上述部分做詳細介紹,

文章目錄

  • 顏色命名空間
    • mpl.colors
      • mpl.colors.BASE_COLORS
      • mpl.colors.TABLEAU_COLORS
      • mpl.colors.cnames
      • mpl.colors.CSS4_COLORS
      • mpl.colors.XKCD_COLORS
      • RGB元組與十六進制字符
      • 可視化CSS4_COLORS
      • 繪制N條漸變線
  • 自定義顏色空間
    • mpl.colors.ListedColormap
    • mpl.colors.LinearSegmentedColormap.from_list
  • 顏色地圖colormap
    • plt.cm
    • plt.cm — listed_cmap
      • 可視化listed_cmap
    • 可視化listed_Seg_cmap
  • 色板 palette
    • 色板命名空間
    • 定制色板
      • 基于plt.cm
      • 基于顏色串列
      • 基于HLS色彩空間生成的離散型色盤
      • 基于球形空間
      • 基于色系
  • 等高線
    • 等高線
    • 等高面
  • 熱力圖
  • 總結

本文的運行環境為 jupyter notebook
python版本為3.7

本文所用到的庫包括

%matplotlib inline
import numpy as np
import seaborn as sns
import matplotlib.pyplot as plt
import matplotlib as mpl

顏色命名空間

mpl.colors模塊下可以看到,matplotlib定制了5個大的顏色空間,有matplotlib默認采用的BASE_COLORS,包含了可視化軟體TableAu顏色命名空間的TABLEAU_COLORS等,各個顏色空間,命名的顏色個數如下,

mpl.colors

print(
    'mpl.colors.BASE_COLORS nums:', len(mpl.colors.BASE_COLORS), '\n',
    'mpl.colors.TABLEAU_COLORS nums:', len(mpl.colors.TABLEAU_COLORS), '\n',
    'mpl.colors.cnames nums:', len(mpl.colors.cnames), '\n',
    'mpl.colors.CSS4_COLORS nums:', len(mpl.colors.CSS4_COLORS), '\n',
    'mpl.colors.XKCD_COLORS nums:', len(mpl.colors.XKCD_COLORS))
顏色命名空間顏色個數
mpl.colors.BASE_COLORS8
mpl.colors.TABLEAU_COLORS10
mpl.colors.cnames148
mpl.colors.CSS4_COLORS148
mpl.colors.XKCD_COLORS949

sns.color_palette可以對包含N個顏色的串列進行可視化,以下對主要命名空間的顏色字典和顏色進行了展示和可視化,

mpl.colors.BASE_COLORS

colors = mpl.colors.BASE_COLORS
print(colors)

pal = [color for name, color in colors.items()]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

{'b': (0, 0, 1), 'g': (0, 0.5, 0), 'r': (1, 0, 0), 'c': (0, 0.75, 0.75), 'm': (0.75, 0, 0.75), 'y': (0.75, 0.75, 0), 'k': (0, 0, 0), 'w': (1, 1, 1)}

mpl.colors.TABLEAU_COLORS

colors = mpl.colors.TABLEAU_COLORS
print(colors)

pal = [color for name, color in colors.items()]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

OrderedDict([('tab:blue', '#1f77b4'), ('tab:orange', '#ff7f0e'), ('tab:green', '#2ca02c'), ('tab:red', '#d62728'), ('tab:purple', '#9467bd'), ('tab:brown', '#8c564b'), ('tab:pink', '#e377c2'), ('tab:gray', '#7f7f7f'), ('tab:olive', '#bcbd22'), ('tab:cyan', '#17becf')])

mpl.colors.cnames

colors = mpl.colors.cnames
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('aliceblue', '#F0F8FF'), ('antiquewhite', '#FAEBD7'), ('aqua', '#00FFFF'), ('aquamarine', '#7FFFD4'), ('azure', '#F0FFFF'), ('beige', '#F5F5DC'), ('bisque', '#FFE4C4'), ('black', '#000000'), ('blanchedalmond', '#FFEBCD'), ('blue', '#0000FF')]

mpl.colors.CSS4_COLORS

colors = mpl.colors.CSS4_COLORS
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('aliceblue', '#F0F8FF'), ('antiquewhite', '#FAEBD7'), ('aqua', '#00FFFF'), ('aquamarine', '#7FFFD4'), ('azure', '#F0FFFF'), ('beige', '#F5F5DC'), ('bisque', '#FFE4C4'), ('black', '#000000'), ('blanchedalmond', '#FFEBCD'), ('blue', '#0000FF')]

mpl.colors.XKCD_COLORS

colors = mpl.colors.XKCD_COLORS
print(list(colors.items())[:10])

pal = [color for name, color in colors.items()][:20]
pal = sns.color_palette(palette=pal)
sns.palplot(pal)

輸出

[('xkcd:cloudy blue', '#acc2d9'), ('xkcd:dark pastel green', '#56ae57'), ('xkcd:dust', '#b2996e'), ('xkcd:electric lime', '#a8ff04'), ('xkcd:fresh green', '#69d84f'), ('xkcd:light eggplant', '#894585'), ('xkcd:nasty green', '#70b23f'), ('xkcd:really light blue', '#d4ffff'), ('xkcd:tea', '#65ab7c'), ('xkcd:warm purple', '#952e8f')]

從以上案例可以看到,一些命名空間的顏色是通過十六進制字串形式表示的,另一些是通過0-1的長度為3的元組形式表示的,這兩種有什么區別呢?
本例展示了他們的數學原理,你會看到他們的本質并沒有什么不同,

RGB元組與十六進制字符

def color16_to_rgb(color16):
    # 分別獲得FF,63,47三個十六進制數字
    R16, G16, B16 = color16[1:3], color16[3:5], color16[5:7]
    # 將十六進制轉成十進制
    R10, G10, B10 = int(R16, 16), int(G16, 16), int(B16, 16)  
    # 將十進制轉成歸一化
    R, G, B = R10/255.0, G10/255.0, B10/255.0  
    return (R, G, B), (R10, G10, B10)

color16_to_rgb('#FF6347')

輸出

((1.0, 0.38823529411764707, 0.2784313725490196), (255, 99, 71))

函式color16_to_rgb決議:先將十六進制字串 # 符號后的6個字符分裂為3個,每兩個代表一個十六進制數字,通過int(num,16)可實作將其轉換為十進制,
從回傳值來看,’#FF6347’被轉換成十進制元組——(255, 99, 71),事實上,電腦顯示帶顏色的圖片就是通過三通道的陣列(寬×高×3)實作的,電腦螢屏在不同解析度下被劃分為M×N的小格,每個小格包含3個數字,分別代表紅色通道(R),綠色通道(G),藍色通道(B)的明暗,0表示最暗,255表示最亮,3通道排列組合一共將產生256×256×256=16777216種顏色組合,這便是理論上總的顏色個數,
matplotlib并沒有保存十進制RGB元組,保存的是十進制元組歸一化后的元組,即十進制元組/255.0后的浮點數,
十六進制和RGB元組都能表示顏色,不同的是前者是離散的,后者是連續的,在使用程序中,可充分利用離散資料的唯一性和連續資料的連續性進行相對應的配色,

可通過matplotlib自帶的mpl.colors.to_rgb 介面實作了上述功能,如下圖可知,兩種方式輸出的歸一化后元組完全相同,

mpl.colors.to_rgb('#FF6347')

輸出

(1.0, 0.38823529411764707, 0.2784313725490196)

以下代碼展示了’#FF6347’的顯色效果(左上角子圖)和分通道的顯色效果,

(R, G, B), (R10, G10, B10)=color16_to_rgb('#FF6347')
img=np.zeros(shape=[15,15,3],dtype=np.int)  # 均為0的3通道陣列
imgR,imgG,imgB=img.copy(),img.copy(),img.copy() # 復制為3個,后續分別用來給每個通道賦值

fig,axs=plt.subplots(2,2,figsize=(8,8))
axs=axs.ravel() # 將axs拉平成一維串列

# 去掉所有子圖坐標系
for ax in axs:
    ax.axis('off')

# R,G,B channels —— ax0
img[:,:,0]=R10
img[:,:,1]=G10
img[:,:,2]=B10
axs[0].imshow(img)
axs[0].set_title('img R,G,B channels\nvalues: %d,%d,%d '% (R10,G10,B10),fontsize=20)

# R channel —— ax1
imgR[:,:,0]=R10
axs[1].imshow(imgR)
axs[1].set_title('img R channel\nvalue: %d'%R10,fontsize=20)

# G channel —— ax2
imgG[:,:,1]=G10
axs[2].imshow(imgG)
axs[2].set_title('img G channel\nvalue: %d'%G10,fontsize=20)

# B channel —— ax3
imgB[:,:,2]=B10
axs[3].imshow(imgB)
axs[3].set_title('img B channel\nvalue: %d'%B10,fontsize=20)

可視化CSS4_COLORS

以下代碼可視化地展示了CSS4_COLORS命名空間各顏色的名稱及顯色效果,根據顯色效果,使用者可根據十六進制字串或顏色名稱進行相應呼叫,

fig, axs = plt.subplots(37, 8, figsize=(12, 20))
axs = axs.ravel()  # 將axs拉平成一維串列

colors = mpl.colors.CSS4_COLORS  # 字典,包含148個元素

for i, (name, color) in enumerate(colors.items()):
    ax_color = axs[2*i]  # 偶數子圖填充顏色并列印顏色十六進制字符
    ax_name = axs[2*i+1]  # 奇數子圖列印顏色名稱

    # 去除x,y軸標簽
    for ax in [ax_color, ax_name]:
        ax.set_xticks([])
        ax.set_yticks([])

    ax_color.set(facecolor=color)  # 顏色子圖填充該顏色

    # 將十六進制顏色字符列印至子圖ax_color
    ax_color.text(0.5, 0.5, color, va='center', ha='center',
                  fontsize=12, transform=ax_color.transAxes)
    # 將顏色名稱字符列印至子圖ax_name
    ax_name.text(0.5, 0.5, name, va='center', ha='center',
                 fontsize=12, transform=ax_name.transAxes)

plt.tight_layout(pad=0)
plt.subplots_adjust(wspace=0,hspace=0)  # 子圖水平與垂直方向間距均調成0

繪制N條漸變線

利用RGB元組的資料連續性,可以很快的繪制線性變化的顏色序列,本圖繪制了顏色在R通道上從150-255線性均勻的變化程序,

N = 6
x = np.linspace(-4, 4, 100)
ys = [i+np.sin(x) for i in range(N)]
cs = np.linspace(150, 255, N)

for i, y in enumerate(ys):
    plt.plot(x, y, c=(cs[i]/255.0, 0, 0), lw=10, label='R-%d' % int(cs[i]))
plt.legend(bbox_to_anchor=(1.02, 0.8), fontsize=15, frameon=False)
# plt.xticks([])
# plt.yticks([])

不難看出元組表示的顏色更適合連續資料的映射,十六進制表示的顏色更適合精確命名顏色,

自定義顏色空間

mpl.colors.ListedColormap

ListedColormap定制的是離散型色板,顏色會根據色板串列回圈,
本例在r,g,b三個通道上,線性地生成了20個資料,并通過串列推導式,生成了包含此20個顏色的串列,并將顏色與資料y的大小進行了映射,
從圖中可以看出,y值比較小的時候,顏色為翠綠色,當y值比較大的時候,顏色為亮紫色,

N=20
colors=[(r,g,b) for (r,g,b) in zip(np.linspace(0,1,N),np.linspace(1,0,N),np.linspace(0,1,N))]
my_cmap=mpl.colors.ListedColormap(colors)
plt.cm.register_cmap(name='mycmp',cmap=my_cmap)

x=np.linspace(-np.pi,np.pi,N)
y=np.sin(x)

plt.scatter(x,y,s=200,c=y,cmap=plt.cm.get_cmap('mycmp'))

輸出定制色板的前五種顏色,如下:

plt.cm.get_cmap('mycmp').colors[:5]

輸出

[(0.0, 1.0, 0.0),
 (0.05263157894736842, 0.9473684210526316, 0.05263157894736842),
 (0.10526315789473684, 0.8947368421052632, 0.10526315789473684),
 (0.15789473684210525, 0.8421052631578947, 0.15789473684210525),
 (0.21052631578947367, 0.7894736842105263, 0.21052631578947367)]

mpl.colors.LinearSegmentedColormap.from_list

LinearSegmentedColormap定制的是一個色板演算法,其原理是通過線性的給出3個顏色點,其余顏色通過插值的方式獲得,
本例將色板與y值大小進行了資料映射,從圖中可以看出y較小時為黑色,較大時為白色,中間為藍色,與我們傳入的startcolormidcolorendcolor實作了對應,

startcolor=(0.0,0.0,0.0)  # 全白
midcolor=(0.0,0.0,1.0)  # 全藍
endcolor=(1.0,1.0,1.0)  # 全黑
my_cmap1=mpl.colors.LinearSegmentedColormap.from_list(name='mycmp1',colors=[startcolor,midcolor,endcolor])
plt.cm.register_cmap(name='mycmp1',cmap=my_cmap1)

x=np.linspace(-np.pi,np.pi,N)
y=np.sin(x)

plt.scatter(x,y,s=200,c=y,cmap=plt.cm.get_cmap('mycmp1'))  

顏色地圖colormap

可通過plt.cm直接呼叫已在matplotlib中定制好的色板
以下兩個案例分別將y、x資料與色板進行了資料映射,效果如下,

plt.cm

N=40
np.random.seed(123)
x=np.random.randn(N)
y=np.random.randn(N)
s=np.linspace(100,1000,N)

fig=plt.figure()
ax=fig.add_subplot(111)

mappable=ax.scatter(x,y,c=y,s=s,alpha=0.6,cmap=plt.cm.RdBu)
# 添加顏色條
cb=plt.colorbar(mappable=mappable,ax=ax)

N=40
np.random.seed(123)
x=np.random.randn(N)
y=np.random.randn(N)
s=np.linspace(100,1000,N)

fig=plt.figure(figsize=(6,5))
ax=fig.add_subplot(111)

mappable=ax.scatter(x,y,c=x,s=s,alpha=0.6,cmap=plt.cm.RdBu)
# 添加水平方向顏色條
cb=plt.colorbar(mappable=mappable,ax=ax,orientation='horizontal')

plt.cm — listed_cmap

plt.cm包含很多默認色板,如下:

cmap_all='''Accent = <matplotlib.colors.ListedColormap object>
Accent_r = <matplotlib.colors.ListedColormap object>
Blues = <matplotlib.colors.LinearSegmentedColormap object>
………………
hot = <matplotlib.colors.LinearSegmentedColormap object>
hot_r = <matplotlib.colors.LinearSegmentedColormap object>
hsv = <matplotlib.colors.LinearSegmentedColormap object>
hsv_r = <matplotlib.colors.LinearSegmentedColormap object>
inferno = <matplotlib.colors.ListedColormap object>
inferno_r = <matplotlib.colors.ListedColormap object>
jet = <matplotlib.colors.LinearSegmentedColormap object>
…………………
winter = <matplotlib.colors.LinearSegmentedColormap object>
winter_r = <matplotlib.colors.LinearSegmentedColormap object>'''

提取資訊

def get_cmap_names(string):
    import re
    match=re.match(pattern=r'(.*) = <matplotlib.colors.(.*) object>',string=string)
    return match.group(1),match.group(2)
cmap_dict={}
for cmap_ in cmap_all.split('\n'):
    cmap_name,cmap_cat=get_cmap_names(cmap_)
    cmap_dict[cmap_name]=cmap_cat

listed_cmap_list=[k for k,v in cmap_dict.items() if v=='ListedColormap']
listed_Seg_cmap_list=[k for k,v in cmap_dict.items() if v=='LinearSegmentedColormap']

cmap_dict,listed_cmap_list,listed_Seg_cmap_list
len(listed_cmap_list),len(listed_Seg_cmap_list)

plt.cm共包含38個ListedColormap色板和126個LinearSegmentedColormap

(38, 126)

可視化listed_cmap

將38個ListedColormap色板可視化,如下:

from matplotlib.gridspec import GridSpec
nrows = len(listed_cmap_list)
gs = GridSpec(nrows=nrows, ncols=2, width_ratios=[
              6, 15], left=0, bottom=0, right=1, top=1, wspace=0, hspace=0)
fig = plt.figure(figsize=(8, 12))
plt.xticks([])
plt.yticks([])
x = np.linspace(0, 1, 20)
y = x.reshape(-1, 1)
xv, yv = np.meshgrid(x, y)
for i, listed_map in enumerate(listed_cmap_list):
    # 奇數子圖顯示colormap名稱
    ax = fig.add_subplot(gs[i, 0], frameon=True)
    ax.text(0.5, 0.5, listed_map, fontdict={
            'size': 17}, ha='center', va='center', transform=ax.transAxes)
    ax.set_xticks([])
    ax.set_yticks([])
    # 偶數子圖繪制colormap漸變顏色
    ax = fig.add_subplot(gs[i, 1], frameon=True)
    ax.imshow(xv, cmap=plt.cm.get_cmap(listed_map), aspect='auto'  # auto 自動調節以充滿整個ax
              , extent=(0, 1, 0, 1))  # 通過增加extent,從而充滿整個ax坐標軸
    ax.set_xticks([])
    ax.set_yticks([])

可視化listed_Seg_cmap

將126個LinearSegmentedColormap色板可視化,如下:

nrows = len(listed_Seg_cmap_list)
gs = GridSpec(nrows=nrows, ncols=2, width_ratios=[
              6, 15], left=0, bottom=0, right=1, top=1, wspace=0, hspace=0)
fig = plt.figure(figsize=(12, 35))
plt.xticks([])
plt.yticks([])
x = np.linspace(0, 1, 20)
y = x.reshape(-1, 1)
xv, yv = np.meshgrid(x, y)

for i, listed_map in enumerate(listed_Seg_cmap_list):
    index = i
    ax = fig.add_subplot(gs[index, 0], frameon=True)
    ax.set_xticks([])
    ax.set_yticks([])
    ax.text(0.5, 0.5, listed_map, fontdict={
            'size': 17}, ha='center', va='center', transform=ax.transAxes)

    ax = fig.add_subplot(gs[index, 1], frameon=True)
    ax.set_xticks([])
    ax.set_yticks([])
    ax.imshow(xv, cmap=plt.cm.get_cmap(listed_map), aspect='auto'  # auto 自動調節以充滿整個ax
              , extent=(0, 1, 0, 1))  # 通過增加extent,從而充滿整個ax坐標軸

色板 palette

seaborn是在matplolib基礎上封裝的高級可視化庫,其色板主要通過palette引數設定

色板命名空間

seaborn默認6種色板命名空間:deep,muted, pastel, bright, dark, colorblind
各色板顏色變化順序如下:

pal = sns.color_palette(palette='deep')
sns.palplot(pal)

pal = sns.color_palette(palette='muted')
sns.palplot(pal)

pal = sns.color_palette(palette='pastel')
sns.palplot(pal)

pal = sns.color_palette(palette='bright')
sns.palplot(pal)

pal = sns.color_palette(palette='dark')
sns.palplot(pal)

pal = sns.color_palette(palette='colorblind')
sns.palplot(pal)

定制色板

有多種方式定制seabornpalette

基于plt.cm

pal=pal_from_cmap=sns.color_palette('hot')
sns.palplot(pal)

基于顏色串列

colors=[(r,g,b) for r,g,b in zip(np.linspace(0,1,5),np.linspace(0.2,0.7,5),np.linspace(0,1,5))]
pal=pal_from_colors=sns.color_palette(colors)
sns.palplot(pal)

基于HLS色彩空間生成的離散型色盤

pal=sns.hls_palette(n_colors=10, h=0.5, l=0.6, s=0.3)
sns.palplot(pal)

基于球形空間

# 基于球形空間生成的線性色盤
pal=sns.cubehelix_palette(n_colors=10,
                            start=1,
                            rot=0.4,
                            gamma=1.0,
                            hue=0.8,
                            light=0.85,
                            dark=0.15,)
sns.palplot(pal)

基于色系

pal=sns.dark_palette(color='red',n_colors=10,)
sns.palplot(pal)

pal=sns.light_palette(color='red',n_colors=10,)
sns.palplot(pal)

色板最直接、最明顯的應用繪圖物件包括:散點圖、面積圖、填充圖、等高線圖、等高面圖、熱力圖等,前三個已經本系列第二部分做了詳細介紹,以下對剩下幾個繪圖物件做案例介紹,細節處請詳細閱讀代碼注釋:

等高線

等高線

N = 10
x = np.linspace(-10, 10, N)
y = np.linspace(-10, 10, N)
X, Y = np.meshgrid(x, y)  # return X,Y, shape 100*100,100*100
# 這里的X,Y可以這么理解,相當于把x軸上的點,和y軸上的點投影到了 2D平面

# 針對2D平面的每一個坐標點,計算Z的值, Z shape 100*100
Z = np.power(X/0.8, 2)+np.power(Y/0.6, 2)

fig = plt.figure()
ax = fig.add_subplot(111)
# levels 顯示指定的Z值 比如 x=0,y=-10,此時 Z=100
CS = ax.contour(X, Y, Z, levels=[20, 40, 70,
                                 100, 150], cmap=plt.cm.RdBu, linewidths=5)
ax.clabel(CS, fontsize=16, fmt='%.0f')

cb = plt.colorbar(mappable=CS)

等高面

N = 1000
x = np.linspace(0, 10, N)
y = np.linspace(-10, 10, N)
X, Y = np.meshgrid(x, y)  # return X,Y, shape 100*100,100*100
# 這里的X,Y可以這么理解,相當于把x軸上的點,和y軸上的點投影到了 2D平面

Z = np.power(X, 2)-np.power(Y, 2)  # 針對2D平面的每一個坐標點,計算Z的值, Z shape 100*100
fig = plt.figure()
ax = fig.add_subplot(111)
ax.set_xlim(-1, 11)
ax.set_ylim(-12, 12)

CS = ax.contourf(X, Y, Z  # ,levels=[-100,-50,50,100]
                 , cmap=plt.cm.Blues
                 )  # levels 顯示指定的Z值 比如 x=0,y=-10,此時 Z=100
ax.clabel(CS, fontsize=16, fmt='%.0f', inline=False, colors='black')

cb = plt.colorbar(mappable=CS)
ax.spines['top'].set_visible(False)
ax.spines['right'].set_visible(False)
ax.plot(x, x, c=(0.75, 0, 0), lw=4, ls='--')

熱力圖

grid_kws = {"height_ratios": (0.9, 0.1)}  # 熱力圖與顏色條高度比值為 0.9:0.1
fig, (ax, cbar_ax) = plt.subplots(
    2, 1, gridspec_kw=grid_kws)  # 2行1列,第一行為熱力圖,第二行為顏色條

data = np.random.randn(64).reshape(8, -1)
sns.heatmap(data,
            ax=ax,
            cbar_ax=cbar_ax,
            cbar=True,
            cbar_kws={"orientation": "horizontal"})  # 將顏色條方向調為水平方向

總結

顏色命名空間 mpl.colors 總結

命名空間型別顏色個數
BASE_COLORS字典顏色名稱RGB元組8
TABLEAU_COLORS字典顏色名稱十六進制10
cnames字典顏色名稱十六進制148
CSS4_COLORS字典顏色名稱十六進制148
XKCD_COLORS字典顏色名稱十六進制949

plt.cm 總結

顏色板型別色板個數創建/參考舉例
ListedColormap字典RGB元組38plt.cm.Accent
LinearSegmentedColormap字典RGB元組126plt.cm.hot

自定義
ListedColormap
串列RGB元組任意多
mpl.colors.ListedColormap(colors)
plt.cm.get_cmap(‘mycmap’)

自定義
LinearSegmentedColormap
串列
3個RGB元組數學運算得到
(start,mid,end)
任意多
mpl.colors.LinearSegmentedColormap.from_list(name,colors)
plt.cm.get_cmap(‘mycmap’)

希望對你有所幫助和啟發!

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/58047.html

標籤:其他

上一篇:kafka

下一篇:python 實作文本自動翻譯功能

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more