主頁 > 軟體設計 > python可視化(4)色板(mpl.colors, colormap, plt.cm, palette)

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

2020-09-17 09:33:08 軟體設計

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/ruanti/64590.html

標籤:其他

上一篇:【練習筆記(第一次)】2020年數學建模國賽C題:資料處理、源代碼

下一篇: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)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more