使用 cycler 設定樣式#

自訂屬性循環設定的示範,用於控制多線圖的顏色和其他樣式屬性。

注意

有關 cycler API 的更完整文件,請參閱這裡

此範例示範兩種不同的 API

  1. 設定指定預設屬性循環的 rc 參數。這會影響所有後續的軸 (但不會影響已經建立的軸)。

  2. 為單一軸對設定屬性循環。

from cycler import cycler

import matplotlib.pyplot as plt
import numpy as np

首先,我們將產生一些範例資料,在此範例中,為四個偏移的正弦曲線。

x = np.linspace(0, 2 * np.pi, 50)
offsets = np.linspace(0, 2 * np.pi, 4, endpoint=False)
yy = np.transpose([np.sin(x + phi) for phi in offsets])

現在 yy 的形狀為

print(yy.shape)
(50, 4)

因此 yy[:, i] 會給您第 i 個偏移正弦曲線。讓我們使用 matplotlib.pyplot.rc()設定預設的 prop_cycle。我們將透過將兩個 cycler 加總 (+) 來組合顏色循環器和線條樣式循環器。請參閱本教學的底部,以了解有關組合不同循環器的更多資訊。

default_cycler = (cycler(color=['r', 'g', 'b', 'y']) +
                  cycler(linestyle=['-', '--', ':', '-.']))

plt.rc('lines', linewidth=4)
plt.rc('axes', prop_cycle=default_cycler)

現在我們將產生一個具有兩個軸的圖形,一個在另一個之上。在第一個軸上,我們將使用預設的循環器繪圖。在第二個軸上,我們將使用 matplotlib.axes.Axes.set_prop_cycle()設定 prop_cycle,這只會為此 matplotlib.axes.Axes 實例設定 prop_cycle。我們將使用第二個 cycler,它組合了顏色循環器和線寬循環器。

custom_cycler = (cycler(color=['c', 'm', 'y', 'k']) +
                 cycler(lw=[1, 2, 3, 4]))

fig, (ax0, ax1) = plt.subplots(nrows=2)
ax0.plot(yy)
ax0.set_title('Set default color cycle to rgby')
ax1.set_prop_cycle(custom_cycler)
ax1.plot(yy)
ax1.set_title('Set axes color cycle to cmyk')

# Add a bit more space between the two plots.
fig.subplots_adjust(hspace=0.3)
plt.show()
Set default color cycle to rgby, Set axes color cycle to cmyk

matplotlibrc 檔案或樣式檔案中設定 prop_cycle#

請記住,可以在您的 matplotlibrc 檔案或樣式檔案 (style.mplstyle) 的 axes.prop_cycle 下設定自訂循環器

axes.prop_cycle : cycler(color='bgrcmyk')

循環瀏覽多個屬性#

您可以新增循環器

from cycler import cycler
cc = (cycler(color=list('rgb')) +
      cycler(linestyle=['-', '--', '-.']))
for d in cc:
    print(d)

結果為

{'color': 'r', 'linestyle': '-'}
{'color': 'g', 'linestyle': '--'}
{'color': 'b', 'linestyle': '-.'}

您可以相乘循環器

from cycler import cycler
cc = (cycler(color=list('rgb')) *
      cycler(linestyle=['-', '--', '-.']))
for d in cc:
    print(d)

結果為

{'color': 'r', 'linestyle': '-'}
{'color': 'r', 'linestyle': '--'}
{'color': 'r', 'linestyle': '-.'}
{'color': 'g', 'linestyle': '-'}
{'color': 'g', 'linestyle': '--'}
{'color': 'g', 'linestyle': '-.'}
{'color': 'b', 'linestyle': '-'}
{'color': 'b', 'linestyle': '--'}
{'color': 'b', 'linestyle': '-.'}

由 Sphinx-Gallery 產生的圖庫