python繪制發(fā)散型柱狀圖+誤差陰影時(shí)間序列圖+雙坐標(biāo)系時(shí)間序列圖+繪制金字塔圖
1.繪制發(fā)散型柱狀圖
python繪制發(fā)散型柱狀圖,展示單個(gè)指標(biāo)的變化的順序和數(shù)量,在柱子上添加了數(shù)值文本。
實(shí)現(xiàn)代碼:
import numpy as np import pandas as pd import matplotlib as mpl import matplotlib.pyplot as plt import seaborn as sns import warnings warnings.filterwarnings(action='once') df = pd.read_csv("C:\工作\學(xué)習(xí)\數(shù)據(jù)雜壇/datasets/mtcars.csv") x = df.loc[:, ['mpg']] df['mpg_z'] = (x - x.mean()) / x.std() df['colors'] = ['red' if x < 0 else 'green' for x in df['mpg_z']] df.sort_values('mpg_z', inplace=True) df.reset_index(inplace=True) # Draw plot plt.figure(figsize=(10, 6), dpi=80) plt.hlines(y=df.index, ? ? ? ? ? ?xmin=0, ? ? ? ? ? ?xmax=df.mpg_z, ? ? ? ? ? ?color=df.colors, ? ? ? ? ? ?alpha=0.8, ? ? ? ? ? ?linewidth=5) for x, y, tex in zip(df.mpg_z, df.index, df.mpg_z): ? ? t = plt.text(x, y, round(tex, 2), horizontalalignment='right' if x < 0 else 'left', ? ? ? ? ? ? ? ? ?verticalalignment='center', fontdict={'color':'black' if x < 0 else 'black', 'size':10}) # Decorations plt.gca().set(ylabel='$Model', xlabel='$Mileage') plt.yticks(df.index, df.cars, fontsize=12) plt.xticks(fontsize=12) plt.title('Diverging Bars of Car Mileage') plt.grid(linestyle='--', alpha=0.5) plt.show()
實(shí)現(xiàn)效果:
2.繪制帶誤差陰影的時(shí)間序列圖
實(shí)現(xiàn)功能:
python繪制帶誤差陰影的時(shí)間序列圖。
實(shí)現(xiàn)代碼:
from scipy.stats import sem import pandas as pd import matplotlib.pyplot as plt # Import Data df_raw = pd.read_csv('F:\數(shù)據(jù)雜壇\datasets\orders_45d.csv', ? ? ? ? ? ? ? ? ? ? ?parse_dates=['purchase_time', 'purchase_date']) # Prepare Data: Daily Mean and SE Bands df_mean = df_raw.groupby('purchase_date').quantity.mean() df_se = df_raw.groupby('purchase_date').quantity.apply(sem).mul(1.96) # Plot plt.figure(figsize=(10, 6), dpi=80) plt.ylabel("Daily Orders", fontsize=12) x = [d.date().strftime('%Y-%m-%d') for d in df_mean.index] plt.plot(x, df_mean, color="#c72e29", lw=2) plt.fill_between(x, df_mean - df_se, df_mean + df_se, color="#f8f2e4") # Decorations # Lighten borders plt.gca().spines["top"].set_alpha(0) plt.gca().spines["bottom"].set_alpha(1) plt.gca().spines["right"].set_alpha(0) plt.gca().spines["left"].set_alpha(1) plt.xticks(x[::6], [str(d) for d in x[::6]], fontsize=12) plt.title("Daily Order Quantity of Brazilian Retail with Error Bands (95% confidence)",fontsize=14) # Axis limits s, e = plt.gca().get_xlim() plt.xlim(s, e - 2) plt.ylim(4, 10) # Draw Horizontal Tick lines for y in range(5, 10, 1): ? ? plt.hlines(y, ? ? ? ? ? ? ? ?xmin=s, ? ? ? ? ? ? ? ?xmax=e, ? ? ? ? ? ? ? ?colors='black', ? ? ? ? ? ? ? ?alpha=0.5, ? ? ? ? ? ? ? ?linestyles="--", ? ? ? ? ? ? ? ?lw=0.5) plt.show()
實(shí)現(xiàn)效果:
3.繪制雙坐標(biāo)系時(shí)間序列圖
實(shí)現(xiàn)功能:
python繪制雙坐標(biāo)系(雙變量)時(shí)間序列圖。
實(shí)現(xiàn)代碼:
import pandas as pd import numpy as np import matplotlib.pyplot as plt # Import Data df = pd.read_csv("F:\數(shù)據(jù)雜壇\datasets\economics.csv") x = df['date'] y1 = df['psavert'] y2 = df['unemploy'] # Plot Line1 (Left Y Axis) fig, ax1 = plt.subplots(1, 1, figsize=(12, 6), dpi=100) ax1.plot(x, y1, color='tab:red') # Plot Line2 (Right Y Axis) ax2 = ax1.twinx() ?# instantiate a second axes that shares the same x-axis ax2.plot(x, y2, color='tab:blue') # Decorations # ax1 (left Y axis) ax1.set_xlabel('Year', fontsize=18) ax1.tick_params(axis='x', rotation=70, labelsize=12) ax1.set_ylabel('Personal Savings Rate', color='#dc2624', fontsize=16) ax1.tick_params(axis='y', rotation=0, labelcolor='#dc2624') ax1.grid(alpha=.4) # ax2 (right Y axis) ax2.set_ylabel("Unemployed (1000's)", color='#01a2d9', fontsize=16) ax2.tick_params(axis='y', labelcolor='#01a2d9') ax2.set_xticks(np.arange(0, len(x), 60)) ax2.set_xticklabels(x [::60], rotation=90, fontdict={'fontsize': 10}) ax2.set_title( ? ? "Personal Savings Rate vs Unemployed: Plotting in Secondary Y Axis", ? ? fontsize=18) fig.tight_layout() plt.show()
實(shí)現(xiàn)效果:
4.繪制金字塔圖
實(shí)現(xiàn)功能:
python繪制金字塔圖,一種排過(guò)序的分組水平柱狀圖barplot,可很好展示不同分組之間的差異,可可視化逐級(jí)過(guò)濾或者漏斗的每個(gè)階段。
實(shí)現(xiàn)代碼:
import pandas as pd import matplotlib.pyplot as plt import seaborn as sns # Read data df = pd.read_csv("D:\數(shù)據(jù)雜壇\datasets\email_campaign_funnel.csv") # Draw Plot plt.figure() group_col = 'Gender' order_of_bars = df.Stage.unique()[::-1] colors = [ ? ? plt.cm.Set1(i / float(len(df[group_col].unique()) - 1)) ? ? for i in range(len(df[group_col].unique())) ] for c, group in zip(colors, df[group_col].unique()): ? ? sns.barplot(x='Users', ? ? ? ? ? ? ? ? y='Stage', ? ? ? ? ? ? ? ? data=df.loc[df[group_col] == group, :], ? ? ? ? ? ? ? ? order=order_of_bars, ? ? ? ? ? ? ? ? color=c, ? ? ? ? ? ? ? ? label=group) # Decorations plt.xlabel("$Users$") plt.ylabel("Stage of Purchase") plt.yticks(fontsize=12) plt.title("Population Pyramid of the Marketing Funnel", fontsize=18) plt.legend() plt.savefig('C:\工作\學(xué)習(xí)\數(shù)據(jù)雜壇\素材\\0815\金字塔', dpi=300, bbox_inches = 'tight') plt.show()
實(shí)現(xiàn)效果:
到此這篇關(guān)于python繪制發(fā)散型柱狀圖+誤差陰影時(shí)間序列圖+雙坐標(biāo)系時(shí)間序列圖+繪制金字塔圖的文章就介紹到這了,更多相關(guān)Python圖繪制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python實(shí)現(xiàn)滑動(dòng)平均(Moving Average)的例子
今天小編就為大家分享一篇Python實(shí)現(xiàn)滑動(dòng)平均(Moving Average)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-08-08Python閉包執(zhí)行時(shí)值的傳遞方式實(shí)例分析
這篇文章主要介紹了Python閉包執(zhí)行時(shí)值的傳遞方式,結(jié)合實(shí)例形式分析了Python閉包執(zhí)行時(shí)的傳值原理與實(shí)現(xiàn)方式,代碼中包含了較為詳盡的注釋便于理解,需要的朋友可以參考下2018-06-06Python中的 No Module named ***問(wèn)題及解決
這篇文章主要介紹了Python中的 No Module named ***問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Python中BaseHTTPRequestHandler實(shí)現(xiàn)簡(jiǎn)單的API接口
本文主要介紹了Python中BaseHTTPRequestHandler實(shí)現(xiàn)簡(jiǎn)單的API接口,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07使用XML庫(kù)的方式,實(shí)現(xiàn)RPC通信的方法(推薦)
下面小編就為大家?guī)?lái)一篇使用XML庫(kù)的方式,實(shí)現(xiàn)RPC通信的方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06Flask搭建api服務(wù)的實(shí)現(xiàn)步驟
本文主要介紹了Flask搭建api服務(wù)的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06python中常見(jiàn)進(jìn)制之間的轉(zhuǎn)換方式
這篇文章主要介紹了python中常見(jiàn)進(jìn)制之間的轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05Caffe卷積神經(jīng)網(wǎng)絡(luò)數(shù)據(jù)層及參數(shù)
這篇文章主要為大家介紹了Caffe卷積神經(jīng)網(wǎng)絡(luò)數(shù)據(jù)層及參數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06