欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何利用Python matplotlib繪制雷達圖

 更新時間:2020年12月21日 14:46:39   作者:Python碎片  
這篇文章主要給大家介紹了關(guān)于如何利用Python matplotlib繪制雷達圖的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

本篇文章介紹使用matplotlib繪制雷達圖。

雷達圖也被稱為網(wǎng)絡(luò)圖,蜘蛛圖,星圖,蜘蛛網(wǎng)圖,是一個不規(guī)則的多邊形。雷達圖可以形象地展示相同事物的多維指標,雷達圖幾乎隨處可見,應(yīng)用場景非常多。

一、matplotlib繪制圓形雷達圖

# coding=utf-8
import numpy as np
import matplotlib.pyplot as plt
 
 
results = [{"大學(xué)英語": 87, "高等數(shù)學(xué)": 79, "體育": 95, "計算機基礎(chǔ)": 92, "程序設(shè)計": 85},
   {"大學(xué)英語": 80, "高等數(shù)學(xué)": 90, "體育": 91, "計算機基礎(chǔ)": 85, "程序設(shè)計": 88}]
data_length = len(results[0])
# 將極坐標根據(jù)數(shù)據(jù)長度進行等分
angles = np.linspace(0, 2*np.pi, data_length, endpoint=False)
labels = [key for key in results[0].keys()]
score = [[v for v in result.values()] for result in results]
# 使雷達圖數(shù)據(jù)封閉
score_a = np.concatenate((score[0], [score[0][0]]))
score_b = np.concatenate((score[1], [score[1][0]]))
angles = np.concatenate((angles, [angles[0]]))
labels = np.concatenate((labels, [labels[0]]))
# 設(shè)置圖形的大小
fig = plt.figure(figsize=(8, 6), dpi=100)
# 新建一個子圖
ax = plt.subplot(111, polar=True)
# 繪制雷達圖
ax.plot(angles, score_a, color='g')
ax.plot(angles, score_b, color='b')
# 設(shè)置雷達圖中每一項的標簽顯示
ax.set_thetagrids(angles*180/np.pi, labels)
# 設(shè)置雷達圖的0度起始位置
ax.set_theta_zero_location('N')
# 設(shè)置雷達圖的坐標刻度范圍
ax.set_rlim(0, 100)
# 設(shè)置雷達圖的坐標值顯示角度,相對于起始角度的偏移量
ax.set_rlabel_position(270)
ax.set_title("計算機專業(yè)大一(上)")
plt.legend(["弓長張", "口天吳"], loc='best')
plt.show()

運行結(jié)果:

繪制雷達圖需要先建立極坐標系,關(guān)于極坐標系可以自己了解一下。建立好極坐標后可以在極坐標中繪制折線圖、柱狀圖等,大部分情況,都是用折線圖,形成一個不規(guī)則的閉合多邊形。本文中用某高校大一的期末考試成績作為例子來演示雷達圖的效果。

linspace(): 用于將極坐標根據(jù)數(shù)據(jù)的維度進行等分,第一個參數(shù)傳入起始角度,第二參數(shù)傳入結(jié)束角度,第三個參數(shù)傳入分成多少等份。其他參數(shù)根據(jù)需要傳入,如endpoint默認為True,最后一個數(shù)據(jù)處于結(jié)束的角度,根據(jù)本例中前面的參數(shù)0~2π,應(yīng)該設(shè)置為False,否則最后一個數(shù)據(jù)與第一個數(shù)據(jù)角度重疊了。

concatenate(): 使雷達圖的數(shù)據(jù)是環(huán)形封閉的,concatenate()函數(shù)的第一個參數(shù)是一個元組,元組中的每個元素是一個數(shù)組,concatenate()函數(shù)將這些數(shù)組連接到一起,組成一個新的數(shù)組。要讓繪制的雷達圖封閉,將數(shù)據(jù)的第一個值連接到數(shù)據(jù)的結(jié)尾即可。

本文用折線圖plot()來繪制雷達圖,使用figure()函數(shù)設(shè)置好圖形的大小和清晰度,然后使用subplot()函數(shù)來創(chuàng)建一張子圖。subplot()函數(shù)的第一個參數(shù)傳入長度為3的數(shù)字,第一個數(shù)字表示將畫布分成幾行,第二個數(shù)字表示將畫布分成幾列,第三個數(shù)字表示當前的子圖處于哪個位置(按從左至右、從上到下的順序排序),第三個數(shù)字不能超出前兩個數(shù)字切分的子圖數(shù)范圍。如111表示將畫布分成一行一列(只有一張子圖),當前的子圖處于第一張子圖中。在subplot()函數(shù)中,將polar參數(shù)設(shè)置True,得到的圖形才是極坐標。

極坐標系設(shè)置完成后,使用子圖對象ax調(diào)用折線圖函數(shù)plot(),即可繪出雷達圖。如果有多組數(shù)據(jù),多次調(diào)用plot()函數(shù)即可。

使用set_thetagrids()函數(shù)設(shè)置雷達圖中每個維度的標簽和顯示位置。使用set_theta_zero_location()函數(shù)設(shè)置雷達圖的0度位置,可以傳入"N"、"NW"、"W"、"SW"、"S"、"SE"、"E"、"NE"八個方位縮寫。使用set_rlim()函數(shù)設(shè)置極坐標上的刻度范圍。使用set_rlabel_position()函數(shù)設(shè)置極坐標上的刻度標簽顯示位置,傳入一個相對于雷達圖0度的角度值。當然還可以根據(jù)需要設(shè)置其他屬性,如標題、圖例等。

在上面的例子中,將兩位同學(xué)的考試成績繪制成了雷達圖,通過雷達圖,可以看出兩個人的單科成績互有高低,而整體來看,兩位同學(xué)成績都很優(yōu)秀。上面的雷達圖中,網(wǎng)格線都是圓形的,而用折線圖連接的雷達圖兩個維度之間是直接連接的,所以將網(wǎng)格線換成多邊形會更合理一點。

二、matplotlib繪制多邊形雷達圖

import numpy as np
import matplotlib.pyplot as plt
 
 
results = [{"大學(xué)英語": 87, "高等數(shù)學(xué)": 79, "體育": 95, "計算機基礎(chǔ)": 92, "程序設(shè)計": 85},
   {"大學(xué)英語": 80, "高等數(shù)學(xué)": 90, "體育": 91, "計算機基礎(chǔ)": 85, "程序設(shè)計": 88}]
data_length = len(results[0])
angles = np.linspace(0, 2*np.pi, data_length, endpoint=False)
labels = [key for key in results[0].keys()]
score = [[v for v in result.values()] for result in results]
score_a = np.concatenate((score[0], [score[0][0]]))
score_b = np.concatenate((score[1], [score[1][0]]))
angles = np.concatenate((angles, [angles[0]]))
labels = np.concatenate((labels, [labels[0]]))
fig = plt.figure(figsize=(10, 6), dpi=100)
fig.suptitle("計算機專業(yè)大一(上)")
ax1 = plt.subplot(121, polar=True)
ax2 = plt.subplot(122, polar=True)
ax, data, name = [ax1, ax2], [score_a, score_b], ["弓長張", "口天吳"]
for i in range(2):
 for j in np.arange(0, 100+20, 20):
  ax[i].plot(angles, 6*[j], '-.', lw=0.5, color='black')
 for j in range(5):
  ax[i].plot([angles[j], angles[j]], [0, 100], '-.', lw=0.5, color='black')
 ax[i].plot(angles, data[i], color='b')
 # 隱藏最外圈的圓
 ax[i].spines['polar'].set_visible(False)
 # 隱藏圓形網(wǎng)格線
 ax[i].grid(False)
 for a, b in zip(angles, data[i]):
  ax[i].text(a, b+5, '%.00f' % b, ha='center', va='center', fontsize=12, color='b')
 ax[i].set_thetagrids(angles*180/np.pi, labels)
 ax[i].set_theta_zero_location('N')
 ax[i].set_rlim(0, 100)
 ax[i].set_rlabel_position(0)
 ax[i].set_title(name[i])
plt.show()

運行結(jié)果:

在極坐標系中,極徑值相等的點在一個圓上,所以繪制的雷達圖中,網(wǎng)格線默認都是圓形的。如果要繪制多邊形的雷達圖,則需要將圓形的網(wǎng)格線隱藏,然后根據(jù)刻度范圍繪制出多邊形的網(wǎng)格線。

首先使用plot()函數(shù),根據(jù)刻度范圍,繪制出同心的多個多邊形和多個維度方向的極軸,作為雷達圖的網(wǎng)格線,形成一張“網(wǎng)”。

鏈式調(diào)用極坐標的spines['polar'].set_visible()函數(shù),傳入?yún)?shù)False,將極坐標系最外圈的圓形隱藏。調(diào)用grid()函數(shù),傳入?yún)?shù)False,將極坐標系中的的圓形網(wǎng)格線隱藏。

修改完網(wǎng)格線后,即可達到多邊形的效果。在第二次繪制雷達圖時,將兩位同學(xué)的成績分到兩張不同的雷達圖中,并用text()設(shè)置了每個維度的數(shù)據(jù)標注,使用suptitle()函數(shù)來設(shè)置整張圖形的標題。

上面的兩次繪圖,將兩位同學(xué)的成績繪制在同一張雷達圖時,更方便對比兩位同學(xué)的成績,如比較誰更全面、更優(yōu)秀。分開繪制時,更方便分析個人的成績情況,如是否偏科。而相對于圓形的雷達圖,在多邊形的雷達圖中,不會出現(xiàn)雷達圖與網(wǎng)格線的不合理交叉(雷達圖與網(wǎng)格線交叉兩次),使用多邊形網(wǎng)格線更合理。

到此這篇關(guān)于如何利用Python matplotlib繪制雷達圖的文章就介紹到這了,更多相關(guān)Python matplotlib繪制雷達圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python入門之列表用法詳解

    Python入門之列表用法詳解

    列表是元素的集合,存儲在一個變量中。這篇文章主要為大家介紹一下Python中列表的定義與使用,文中的示例代碼講解詳細,需要的可以參考一下
    2022-09-09
  • Python利用Redis計算經(jīng)緯度距離案例

    Python利用Redis計算經(jīng)緯度距離案例

    這篇文章主要介紹了Python利用Redis計算經(jīng)緯度距離案例,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-09-09
  • 使用 django orm 寫 exists 條件過濾實例

    使用 django orm 寫 exists 條件過濾實例

    這篇文章主要介紹了使用 django orm 寫 exists 條件過濾實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Python 使用 Redis 作為緩存的操作方法

    Python 使用 Redis 作為緩存的操作方法

    在現(xiàn)代Web應(yīng)用和數(shù)據(jù)密集型服務(wù)中,使用Redis作為緩存可以提升性能和響應(yīng)速度,Redis是一個高性能的內(nèi)存中數(shù)據(jù)結(jié)構(gòu)存儲系統(tǒng),支持多種數(shù)據(jù)結(jié)構(gòu)如字符串、哈希、列表等,并提供持久性和分布式支持,本文給大家介紹Python 使用 Redis 作為緩存的操作方法,感興趣的朋友一起看看吧
    2024-10-10
  • 利用Python繪制Jazz網(wǎng)絡(luò)圖的例子

    利用Python繪制Jazz網(wǎng)絡(luò)圖的例子

    今天小編就為大家分享一篇利用Python繪制Jazz網(wǎng)絡(luò)圖的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python多線程編程(三):threading.Thread類的重要函數(shù)和方法

    Python多線程編程(三):threading.Thread類的重要函數(shù)和方法

    這篇文章主要介紹了Python多線程編程(三):threading.Thread類的重要函數(shù)和方法,本文講解了線程名稱、join方法、setDaemon方法等內(nèi)容,需要的朋友可以參考下
    2015-04-04
  • Python記錄numpy.empty()函數(shù)引發(fā)的問題及解決

    Python記錄numpy.empty()函數(shù)引發(fā)的問題及解決

    這篇文章主要介紹了Python記錄numpy.empty()函數(shù)引發(fā)的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Python判斷文件或文件夾是否存在的三種方法

    Python判斷文件或文件夾是否存在的三種方法

    本文給大家介紹三種判斷文件或文件夾是否存在的方法,分別使用os模塊、Try語句、pathlib模塊。感興趣的朋友一起看看吧
    2017-07-07
  • PyTorch的深度學(xué)習(xí)入門教程之構(gòu)建神經(jīng)網(wǎng)絡(luò)

    PyTorch的深度學(xué)習(xí)入門教程之構(gòu)建神經(jīng)網(wǎng)絡(luò)

    這篇文章主要介紹了PyTorch的深度學(xué)習(xí)入門教程之構(gòu)建神經(jīng)網(wǎng)絡(luò),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 使用python socket分發(fā)大文件的實現(xiàn)方法

    使用python socket分發(fā)大文件的實現(xiàn)方法

    今天小編就為大家分享一篇使用python socket分發(fā)大文件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07

最新評論