在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python數(shù)據(jù)可視化:類別比較圖表可視化

jf_Vqngj70R ? 來源:美男子玩編程 ? 作者:美男子玩編程 ? 2022-11-15 15:09 ? 次閱讀

在學(xué)習(xí)本篇博文之前請先看一看之前發(fā)過的關(guān)聯(lián)知識:

Python數(shù)據(jù)可視化:如何選擇合適的圖表可視化?

根據(jù)表達數(shù)據(jù)的側(cè)重內(nèi)容點,將圖表類型分為6大類:類別比較圖表、數(shù)據(jù)關(guān)系圖表、數(shù)據(jù)分布圖表、時間序列圖表、局部整體圖表和地理空間圖表(有些圖表也可以歸類于兩種或多種圖表類型)。

本篇將介紹類別比較圖表的可視化方法。

類別比較型圖表的數(shù)據(jù)一般分為:數(shù)值型和類別型兩種數(shù)據(jù)類型,主要包括:柱形圖、條形圖、雷達圖、詞云圖等,通常用來比較數(shù)據(jù)的規(guī)模。如下所示:

e016fbd8-649a-11ed-8abf-dac502259ad0.png

1

柱狀圖

柱形圖是一種以長方形的長度為變量的統(tǒng)計圖表。柱形圖用于顯示一段時間內(nèi)的數(shù)據(jù)變化或顯示各項之間的比較情況。

在柱形圖中,類別型或序數(shù)型變量映射到橫軸的位置,數(shù)值型變量映射到矩形的高度。控制柱形圖的兩個重要參數(shù)是:“系列重疊"和“分類間距”。

  • “分類間距"控制同一數(shù)據(jù)系列的柱形寬度;

  • “系列重疊"控制不同數(shù)據(jù)系列之間的距離。

下圖為常見的柱形圖類型:單數(shù)據(jù)系列柱形圖、多數(shù)據(jù)系列柱形圖、堆積柱形圖和百分比堆積柱形圖。

e05c82a2-649a-11ed-8abf-dac502259ad0.png

1.1、單數(shù)據(jù)系列柱形圖

通過一個示例了解單數(shù)據(jù)系列柱形圖的使用,實現(xiàn)代碼如下所示:

mydata = pd.DataFrame({'Cut': ["Fair", "Good", "Very Good", "Premium", "Ideal"],
                       'Price': [4300, 3800, 3950, 4700, 3500]})


Sort_data = mydata.sort_values(by='Price', ascending=False)


fig = plt.figure(figsize=(6, 7), dpi=70)
plt.subplots_adjust(left=0.1, right=0.9, top=0.9, bottom=0.1)
plt.grid(axis="y", c=(217/256, 217/256, 217/256))  # 設(shè)置網(wǎng)格線
# 將網(wǎng)格線置于底層
ax = plt.gca()  # 獲取邊框
ax.spines['top'].set_color('none')  # 設(shè)置上‘脊梁’為紅色
ax.spines['right'].set_color('none')  # 設(shè)置上‘脊梁’為無色
ax.spines['left'].set_color('none')  # 設(shè)置上‘脊梁’為無色


plt.bar(Sort_data['Cut'], Sort_data['Price'],
        width=0.6, align="center", label="Cut")


plt.ylim(0, 6000)  # 設(shè)定x軸范圍
plt.xlabel('Cut')
plt.ylabel('Price')
plt.show()

	

效果如下所示:

e081bb26-649a-11ed-8abf-dac502259ad0.png

1.2、多數(shù)據(jù)系列柱形圖

通過一個示例了解多數(shù)據(jù)系列柱形圖的使用,實現(xiàn)代碼如下所示:


	
x_label = np.array(df["Catergory"])
x = np.arange(len(x_label))
y1 = np.array(df["1996"])
y2 = np.array(df["1997"])


fig = plt.figure(figsize=(5, 5))
plt.subplots_adjust(left=0.1, right=0.9, top=0.9, bottom=0.1)  # 設(shè)置繪圖區(qū)域大小位置


plt.bar(x, y1, width=0.3, color='#00AFBB', label='1996', edgecolor='k',
        linewidth=0.25)  # 調(diào)整y1軸位置,顏色,label為圖例名稱,與下方legend結(jié)合使用
plt.bar(x+0.3, y2, width=0.3, color='#FC4E07', label='1997',
        edgecolor='k', linewidth=0.25)  # 調(diào)整y2軸位置,顏色,label為圖例名稱,與下方legend結(jié)合使用
plt.xticks(x+0.15, x_label, size=12)  # 設(shè)置x軸刻度,位置,大小


# 顯示圖例,loc圖例顯示位置(可以用坐標(biāo)方法顯示),ncol圖例顯示幾列,默認為1列,frameon設(shè)置圖形邊框
plt.legend(loc=(1, 0.5), ncol=1, frameon=False)


plt.yticks(size=12)  # 設(shè)置y軸刻度,位置,大小
plt.grid(axis="y", c=(217/256, 217/256, 217/256))  # 設(shè)置網(wǎng)格線
# 將y軸網(wǎng)格線置于底層
# plt.xlabel("Quarter",labelpad=10,size=18,)                          #設(shè)置x軸標(biāo)簽,labelpad設(shè)置標(biāo)簽距離x軸的位置
# plt.ylabel("Amount",labelpad=10,size=18,)                                   #設(shè)置y軸標(biāo)簽,labelpad設(shè)置標(biāo)簽距離y軸的位置




ax = plt.gca()  
ax.spines['top'].set_color('none')  # 設(shè)置上‘脊梁’為無色
ax.spines['right'].set_color('none')  # 設(shè)置右‘脊梁’為無色
ax.spines['left'].set_color('none')  # 設(shè)置左‘脊梁’為無色


plt.show()

	

效果如下所示:

e09a4de4-649a-11ed-8abf-dac502259ad0.png

1.3、堆積柱形圖

通過一個示例了解堆積柱形圖的使用,實現(xiàn)代碼如下所示:


		
# -*- coding: utf-8 -*-
# %%
import pandas as pd
import numpy as np
from plotnine import *




mydata = pd.DataFrame(dict(Name=['A', 'B', 'C', 'D', 'E'],
                           Scale=[35, 30, 20, 10, 5],
                           ARPU=[56, 37, 63, 57, 59]))


# 構(gòu)造矩形X軸的起點(最小點)
mydata['xmin'] = 0
for i in range(1, 5):
    mydata['xmin'][i] = np.sum(mydata['Scale'][0:i])


# 構(gòu)造矩形X軸的終點(最大點)
mydata['xmax'] = 0
for i in range(0, 5):
    mydata['xmax'][i] = np.sum(mydata['Scale'][0:i+1])


mydata['label'] = 0
for i in range(0, 5):
    mydata['label'][i] = np.sum(mydata['Scale'][0:i+1])-mydata['Scale'][i]/2


base_plot = (ggplot(mydata) +
             geom_rect(aes(xmin='xmin', xmax='xmax', ymin=0, ymax='ARPU', fill='Name'), colour="black", size=0.25) +
             geom_text(aes(x='label', y='ARPU+3', label='ARPU'), size=14, color="black") +
             geom_text(aes(x='label', y=-4, label='Name'), size=14, color="black") +
             scale_fill_hue(s=0.90, l=0.65, h=0.0417, color_space='husl') +
             ylab("ARPU") +
             xlab("scale") +
             ylim(-5, 80) +
             theme(  # panel_background=element_rect(fill="white"),
    #panel_grid_major = element_line(colour = "grey",size=.25,linetype ="dotted" ),
    #panel_grid_minor = element_line(colour = "grey",size=.25,linetype ="dotted" ),
    text=element_text(size=15),
    legend_position="none",
    aspect_ratio=1.15,
    figure_size=(5, 5),
    dpi=100
))
print(base_plot)

2

條形圖

條形圖與柱形圖類似,幾乎可以表達相同多的數(shù)據(jù)信息。

在條形圖中,類別型或序數(shù)型變量映射到縱軸的位置,數(shù)值型變量映射到矩形的寬度。條形圖的柱形變?yōu)闄M向,從而導(dǎo)致與柱形圖相比,條形圖更加強調(diào)項目之間的大小對比。尤其在項目名稱較長以及數(shù)量較多時,采用條形圖可視化數(shù)據(jù)會更加美觀、清晰,如下圖所示:

e139e822-649a-11ed-8abf-dac502259ad0.png

2.1、單數(shù)據(jù)系列條形圖

通過一個示例了解單數(shù)據(jù)系列條形圖的使用,實現(xiàn)代碼如下所示:


		
df = pd.read_csv('Stackedbar_Data.csv')


df = df.sort_values(by='Pensions', ascending=True)


df['Country'] = pd.Categorical(df['Country'], categories=df['Country'], ordered=True)
df


# %%
base_plot = (ggplot(df, aes('Country', 'Pensions')) +
             # "#00AFBB"
             geom_bar(stat="identity", color="black", width=0.6, fill="#FC4E07", size=0.25) +

實現(xiàn)效果如下所示:

e1547b56-649a-11ed-8abf-dac502259ad0.png

2.2、多數(shù)據(jù)系列條形圖

通過一個示例了解多數(shù)據(jù)系列條形圖的使用,實現(xiàn)代碼如下所示:


			
df = pd.read_csv('Stackedbar_Data.csv')

效果如下所示:

e17e22da-649a-11ed-8abf-dac502259ad0.png

2.3、堆積條形圖

通過一個示例了解堆積條形圖的使用,實現(xiàn)代碼如下所示:

df = pd.read_csv('Stackedbar_Data.csv')
Sum_df = df.iloc[nonedisplay: none;'>

e1986816-649a-11ed-8abf-dac502259ad0.png

2.4、百分比堆積條形圖

通過一個示例了解百分比堆積條形圖的使用,實現(xiàn)代碼如下所示:

df = pd.read_csv('Stackedbar_Data.csv')

							

效果如下所示:

e1faa5bc-649a-11ed-8abf-dac502259ad0.png

4

詞云圖

詞云圖通過使每個字的大小與其出現(xiàn)頻率成正比,顯示不同單詞在給定文本中的出現(xiàn)頻率,這會過濾掉大量的文本信息,使瀏覽者只要一眼掃過文本就可以領(lǐng)略文本的主旨。

詞云圖會將所有的字詞排在一起,形成云狀圖案,也可以任何格式排列:水平線、垂直列或其他形狀,也可用于顯示獲分配元數(shù)據(jù)的單詞。如下圖所示:

e33cfb5a-649a-11ed-8abf-dac502259ad0.png每個圓圈表示一個數(shù)值刻度,而徑向分隔線(從中心延伸出來的線)則用于區(qū)分不同類別或間隔(如果是直方圖)??潭壬陷^低的數(shù)值通常由中心點開始,然后數(shù)值會隨著每個圓形往外增加,但也可以把任何外圓設(shè)為零值,這樣里面的內(nèi)圓就可用來顯示負值。條形通常從中心點開始向外延伸,但也可以以別處為起點,顯示數(shù)值范圍(如跨度圖)。

此外,條形也可以如堆疊式條形圖般堆疊起來,如下圖所示:

e3d8bd60-649a-11ed-8abf-dac502259ad0.png

8

熱力圖

熱力圖是一種通過對色塊著色來顯示數(shù)據(jù)的統(tǒng)計圖表,繪圖時需指定顏色映射的規(guī)則。例如,較大的值由較深的顏色表示,較小的值由較淺的顏色表示;較大的值由偏暖的顏色表示,較小的值由較冷的顏色表示等。

通過一個示例了解熱力圖的使用,實現(xiàn)代碼如下所示:

import numpy as np
import pandas as pd
from plotnine import *
from plotnine.data import mtcars


mat_corr = np.round(mtcars.corr(), 1).reset_index()
mydata = pd.melt(mat_corr, id_vars='index', var_name='var', value_name='value')
mydata


# %%
base_plot = (ggplot(mydata, aes(x='index', y='var', fill='value', label='value')) +
             geom_tile(colour="black") +
             geom_text(size=8, colour="white") +
             scale_fill_cmap(name='RdYlBu_r') +
             coord_equal() +
             theme(dpi=100, figure_size=(4, 4)))
print(base_plot)


# %%
mydata['AbsValue'] = np.abs(mydata.value)


base_plot = (ggplot(mydata, aes(x='index', y='var', fill='value', size='AbsValue')) +
             geom_point(shape='o', colour="black") +
             # geom_text(size=8,colour="white")+
             scale_size_area(max_size=11, guide=False) +
             scale_fill_cmap(name='RdYlBu_r') +
             coord_equal() +
             theme(dpi=100, figure_size=(4, 4)))
print(base_plot)


# %%
base_plot = (ggplot(mydata, aes(x='index', y='var', fill='value', size='AbsValue')) +
             geom_point(shape='s', colour="black") +
             # geom_text(size=8,colour="white")+
             scale_size_area(max_size=10, guide=False) +
             scale_fill_cmap(name='RdYlBu_r') +
             coord_equal() +
             theme(dpi=100, figure_size=(4, 4)))
print(base_plot)

							

效果如下所示:

e3f754d2-649a-11ed-8abf-dac502259ad0.png

e41ddce2-649a-11ed-8abf-dac502259ad0.png

e4472886-649a-11ed-8abf-dac502259ad0.png


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 可視化
    +關(guān)注

    關(guān)注

    1

    文章

    1234

    瀏覽量

    21569
  • 圖表
    +關(guān)注

    關(guān)注

    0

    文章

    33

    瀏覽量

    8961
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4822

    瀏覽量

    85923

原文標(biāo)題:Python數(shù)據(jù)可視化:類別比較圖表可視化

文章出處:【微信號:美男子玩編程,微信公眾號:美男子玩編程】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    可視化組態(tài)物聯(lián)網(wǎng)平臺是什么

    可視化含義:組態(tài)是一種用于構(gòu)建復(fù)雜物聯(lián)網(wǎng)系統(tǒng)的工具,它提供了豐富的圖形組件和可視化元素,使得用戶可以通過簡單的拖拽操作來創(chuàng)建自定義的界面。可視化則強調(diào)將物聯(lián)網(wǎng)系統(tǒng)產(chǎn)生的大量
    的頭像 發(fā)表于 04-21 10:40 ?132次閱讀

    VirtualLab Fusion中的可視化設(shè)置

    通過以下控件進行重置、加載和保存: 主窗口設(shè)置 字體配置 數(shù)字顯示 文檔窗口設(shè)置 1D數(shù)據(jù)數(shù)組可視化設(shè)置 顏色表 諧波場視圖
    發(fā)表于 02-25 08:51

    VirtualLab Fusion應(yīng)用:光波導(dǎo)k域布局可視化(“神奇的圓環(huán)”)

    特定光波導(dǎo)布局的光導(dǎo)和耦合條件。 概念 方向轉(zhuǎn)換器計算器 可以通過“開始”>“計算器”找到方向轉(zhuǎn)換器計算器,這有助于演示指定角度的不同方式。 k域可視化 k域可視化:平面波的傳播
    發(fā)表于 02-21 08:53

    七款經(jīng)久不衰的數(shù)據(jù)可視化工具!

    量的激增,單純通過數(shù)字和文本來分析數(shù)據(jù)已不再高效。數(shù)據(jù)可視化則提供了一種直觀、互動性強的方式,幫助人們通過視覺元素,如柱狀圖、折線圖、餅圖、熱力圖等圖表形式,理解復(fù)雜的
    發(fā)表于 01-19 15:24

    什么是大屏數(shù)據(jù)可視化?特點有哪些?

    介紹: 特點 直觀易懂:大屏數(shù)據(jù)可視化通過圖表、圖形和其他可視化元素,將復(fù)雜的數(shù)據(jù)轉(zhuǎn)化為直觀易懂的形式,使得用戶無需深入挖掘
    的頭像 發(fā)表于 12-16 16:59 ?541次閱讀

    Minitab 數(shù)據(jù)可視化技巧

    數(shù)據(jù)分析領(lǐng)域,數(shù)據(jù)可視化是一種將數(shù)據(jù)以圖形或圖像的形式展示出來的技術(shù),它可以幫助我們更直觀地理解數(shù)據(jù),發(fā)現(xiàn)
    的頭像 發(fā)表于 12-02 15:40 ?1073次閱讀

    智慧能源可視化監(jiān)管平臺——助力可視化能源數(shù)據(jù)管理

    博達可視化大屏設(shè)計平臺在智慧能源領(lǐng)域的價值體現(xiàn)在實時監(jiān)控、數(shù)據(jù)可視化、決策支持和效率提升等方面。借助該平臺,企業(yè)可以輕松搭建智慧能源類可視化大屏,更加精確和高效地管理生產(chǎn)和生活,實現(xiàn)能
    的頭像 發(fā)表于 11-29 10:00 ?767次閱讀
    智慧能源<b class='flag-5'>可視化</b>監(jiān)管平臺——助力<b class='flag-5'>可視化</b>能源<b class='flag-5'>數(shù)據(jù)</b>管理

    智慧樓宇可視化的優(yōu)點

    監(jiān)控與管理:智慧樓宇可視化系統(tǒng)可以實時監(jiān)測樓宇各項數(shù)據(jù)指標(biāo),包括能耗、水量、空氣質(zhì)量、安全等情況,讓管理者隨時了解樓宇運行狀態(tài),及時發(fā)現(xiàn)問題并做出調(diào)整。 2.數(shù)據(jù)可視化呈現(xiàn):通過
    的頭像 發(fā)表于 11-19 14:25 ?389次閱讀

    大屏數(shù)據(jù)可視化 開源

    在當(dāng)今信息爆炸的時代,數(shù)據(jù)已經(jīng)成為各個行業(yè)決策制定和業(yè)務(wù)發(fā)展的關(guān)鍵。為了更直觀、準(zhǔn)確地理解和利用海量數(shù)據(jù), 大屏數(shù)據(jù)可視化 成為一種強大的工具。通過將
    的頭像 發(fā)表于 06-27 16:06 ?623次閱讀
    大屏<b class='flag-5'>數(shù)據(jù)</b><b class='flag-5'>可視化</b> 開源

    如何實現(xiàn)園區(qū)大屏可視化?

    如何實現(xiàn)園區(qū)大屏可視化? 1.建立孿生模型:首先需要建立園區(qū)的孿生模型,即一個數(shù)字的虛擬模型,反映了園區(qū)的實際情況、結(jié)構(gòu)、設(shè)備、人員等信息。這個模型可以通過傳感器、監(jiān)控設(shè)備、GIS 數(shù)據(jù)等實時獲取和更新,確保與實際情況保持
    的頭像 發(fā)表于 06-19 15:39 ?659次閱讀
    如何實現(xiàn)園區(qū)大屏<b class='flag-5'>可視化</b>?

    物聯(lián)網(wǎng)時代,為什么需要可視化數(shù)據(jù)大屏

    效率、能耗水平等信息,從而合理優(yōu)化并采取措施,促進企業(yè)的數(shù)字轉(zhuǎn)型。 由于人類大腦對視覺信息的處理優(yōu)于對文本的處理,因此使用圖表、圖形和設(shè)計元素把數(shù)據(jù)進行可視化,可以幫助更容易的了解
    的頭像 發(fā)表于 06-18 13:53 ?616次閱讀
    物聯(lián)網(wǎng)時代,為什么需要<b class='flag-5'>可視化</b><b class='flag-5'>數(shù)據(jù)</b>大屏

    態(tài)勢數(shù)據(jù)可視化技術(shù)有哪些

    智慧華盛恒輝態(tài)勢數(shù)據(jù)可視化技術(shù)是一種將數(shù)據(jù)以圖形、圖像、動畫等視覺形式展現(xiàn)出來的技術(shù),特別是在處理和分析態(tài)勢數(shù)據(jù)時,該技術(shù)能夠?qū)?fù)雜的數(shù)據(jù)轉(zhuǎn)
    的頭像 發(fā)表于 06-11 15:47 ?564次閱讀

    智慧大屏是如何實現(xiàn)數(shù)據(jù)可視化的?

    智慧大屏,作為數(shù)據(jù)可視化的重要載體,已在城市管理、交通監(jiān)控、商業(yè)運營等領(lǐng)域廣泛應(yīng)用。本文旨在闡述智慧大屏實現(xiàn)數(shù)據(jù)可視化的關(guān)鍵技術(shù)和方法,包括數(shù)據(jù)
    的頭像 發(fā)表于 06-04 15:02 ?862次閱讀
    智慧大屏是如何實現(xiàn)<b class='flag-5'>數(shù)據(jù)</b><b class='flag-5'>可視化</b>的?

    大屏數(shù)據(jù)可視化的作用和意義

    大屏數(shù)據(jù)可視化是指利用大屏幕設(shè)備展示數(shù)據(jù)信息,通過圖表、圖像、動畫等視覺手段將數(shù)據(jù)呈現(xiàn)出來,以
    的頭像 發(fā)表于 06-03 17:56 ?976次閱讀
    主站蜘蛛池模板: 在线视频免费观看 | 天天干小说 | 欧美色视频日本片高清在线观看 | japanese色系国产在线高清 | 中文字幕av一区二区三区 | 不卡一区 | 最近2018中文字幕2019高清 | 亚洲二区在线观看 | 天天影视网天天影网 | 人人射人人射 | 亚洲三级理论 | 国内外精品免费视频 | 亚洲www在线 | 黄色三级网站免费 | 老汉影视永久免费视频 | 正在播放一区二区 | 久久99精品久久久久久野外 | 婷婷丁香六月天 | 久久思re热9一区二区三区 | 777奇米影视笫四色88me久久综合 | 99久久成人国产精品免费 | 欧美a色爱欧美综合v | 四虎影院永久网站 | 91成人在线免费视频 | 国产精品高清免费网站 | 亚洲一区二区影视 | 久久羞羞视频 | 综合色图| 成年人黄色免费网站 | 男女在线免费视频 | 丁香花五月婷婷开心 | 国产午夜三级 | 日日拍拍 | 国产成人精品日本 | 又黄又湿又爽吸乳视频 | 免费看黄色网页 | 中文字幕亚洲色图 | a久久 | 99热色| 色一欲一性一乱一区二区三区 | 色综合天天五月色 |