python 繪制斜率圖進行對比分析
你好,我是林驥。
斜率圖,可以快速展現(xiàn)兩組數(shù)據(jù)之間各維度的變化,特別適合用于對比兩個時間點的數(shù)據(jù)。
比如說,為了對比分析某產(chǎn)品不同功能的用戶滿意度,經(jīng)過問卷調(diào)查和數(shù)據(jù)統(tǒng)計,得到下面這個調(diào)查結(jié)果:
你不妨自己先思考一下,如何對這組數(shù)據(jù)進行可視化,才能讓信息傳遞變得更加高效?
下面是我用 matplotlib 制作的圖表:
從圖中可以直觀地看出,功能 C 的用戶滿意度明顯下降,我們用比較鮮明的橙色來表示,以便引起觀眾重點關(guān)注;功能 D 和功能 E 的用戶滿意度明顯提升,我們用藍色表示,代表數(shù)據(jù)正在向好的方向發(fā)展;功能 A 和功能 B 的用戶滿意度變化不大,我們用淺灰色表示,以便削弱觀眾對這兩個功能的注意力,把更多的精力用于分析用戶滿意度明顯下降的功能點,從而讓圖表起到提升信息傳遞效率的目的。
下面是用 matplotlib 畫圖的詳細步驟。首先,導入所需的庫,并設(shè)置中文字體和定義顏色等。
# 導入所需的庫import numpy as npimport pandas as pdimport matplotlib as mplimport matplotlib.pyplot as pltimport matplotlib.image as image# 正常顯示中文標簽mpl.rcParams[’font.sans-serif’] = [’SimHei’]# 自動適應布局mpl.rcParams.update({’figure.autolayout’: True})# 正常顯示負號mpl.rcParams[’axes.unicode_minus’] = False# 定義顏色,主色:藍色,輔助色:灰色,互補色:橙色c = {’藍色’:’#00589F’, ’深藍色’:’#003867’, ’淺藍色’:’#5D9BCF’, ’灰色’:’#999999’, ’深灰色’:’#666666’, ’淺灰色’:’#CCCCCC’, ’橙色’:’#F68F00’, ’深橙色’:’#A05D00’, ’淺橙色’:’#FBC171’}
其次,從 Excel 文件中讀取隨機模擬的數(shù)據(jù),并定義畫圖用的數(shù)據(jù)。
# 數(shù)據(jù)源路徑filepath=’./data/問卷調(diào)查結(jié)果.xlsx’# 讀取 Excel文件df = pd.read_excel(filepath, index_col=’調(diào)查年度’)# 定義畫圖用的數(shù)據(jù)category_names = df.columnslabels = df.indexdata = df.valuesdata_cum = data.cumsum(axis=1)
接下來,開始用「面向?qū)ο蟆沟姆椒ㄟM行畫圖。
# 使用「面向?qū)ο蟆沟姆椒ó媹D,定義圖片的大小fig, ax=plt.subplots(figsize=(6, 6))# 設(shè)置背景顏色fig.set_facecolor(’w’)ax.set_facecolor(’w’)# 設(shè)置標題ax.set_title(’n用戶滿意度隨時間的變化n’, fontsize=26, loc=’left’, color=c[’深灰色’])# 定義顏色category_colors = [c[’淺灰色’], c[’淺灰色’], c[’橙色’], c[’藍色’], c[’藍色’]]# 畫斜率圖for i, color in zip(np.arange(len(df.columns)), category_colors): ax.plot(df.index, df.iloc[:, i], marker=’o’, color=color) # 設(shè)置數(shù)據(jù)標簽及其文字顏色 ax.text(-0.03, df.iloc[0, i], df.columns[i] + ’ ’ + ’{:.0%}’.format(df.iloc[0, i]), ha=’right’, va=’center’, color=color, fontsize=16) ax.text(1.06, df.iloc[1, i], ’{:.0%}’.format(df.iloc[1, i]), ha=’left’, va=’center’, color=color, fontsize=16)# 設(shè)置 Y 軸刻度范圍ax.set_ylim(df.values.min()-0.02, df.values.max()+0.01)# 隱藏 Y 軸ax.yaxis.set_visible(False)# 隱藏邊框ax.spines[’top’].set_visible(False)ax.spines[’right’].set_visible(False)ax.spines[’left’].set_visible(False)ax.spines[’bottom’].set_visible(False)# 隱藏 X 軸的刻度線ax.tick_params(axis=’x’, which=’major’, length=0)# 設(shè)置坐標標簽字體大小和顏色ax.tick_params(labelsize=16, colors=c[’灰色’])plt.show()
運行之后,便得到上面那張圖。
你可以前往 https://github.com/linjiwx/mp 下載畫圖用的數(shù)據(jù)和完整代碼。
對于同一組數(shù)據(jù),不同的人可能會有不同的觀察視角,對它們進行可視化,往往也存在多種不同的解決方案,這里介紹的方法,并不是唯一正確的答案。關(guān)鍵在于,圖表的設(shè)計者想要表達什么信息?是否讓觀眾正確且快速地理解了想要表達的信息?
不同類型的圖表,有著不同的優(yōu)勢和劣勢。
斜率圖的優(yōu)勢,是能快速看到每個類別前后發(fā)生的變化,并能根據(jù)線條的陡峭程度,直觀地感受到變化的幅度。
斜率圖的劣勢,是看不出整體與部分的占比關(guān)系。另外,如果類別的順序很重要,那么也不適合使用斜率圖,因為類別會根據(jù)數(shù)值大小自動進行排列。
最后,留給你一道思考題:在你看到過的各種數(shù)據(jù)中,有哪些數(shù)據(jù)是適合用斜率圖進行對比分析的?
當你不知道該選擇什么類型的圖表時,不妨停下來想一想,你希望讓觀眾了解什么或者做什么?
以上就是python 繪制斜率圖進行對比分析的詳細內(nèi)容,更多關(guān)于python 對比分析的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. Ajax實現(xiàn)表格中信息不刷新頁面進行更新數(shù)據(jù)2. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明3. 解決AJAX返回狀態(tài)200沒有調(diào)用success的問題4. PHP設(shè)計模式中工廠模式深入詳解5. CSS hack用法案例詳解6. JSP數(shù)據(jù)交互實現(xiàn)過程解析7. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向8. 利用promise及參數(shù)解構(gòu)封裝ajax請求的方法9. ThinkPHP5實現(xiàn)JWT Token認證的過程(親測可用)10. .NET中l(wèi)ambda表達式合并問題及解決方法
