成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一個經典案例掌握 Plotly 餅圖繪制技巧

大數據 數據可視化
當需要展示同一數據的不同維度比例,或比較不同數據集的構成時,Plotly的子圖餅圖組合提供了一種強大而優雅的解決方案。

Plotly庫以其卓越的交互性和定制能力,使得創建這種精美的多餅圖布局成為可能。本文將通過一個案例,展示如何利用 Plotly 繪制一組相互關聯、視覺效果的餅圖。

一、準備工作

開始創作前,請確保你的 Python 環境已安裝 Plotly 和 Pandas:

pip install plotly pandas

導入所需模塊:

import plotly.graph_objects as go
from plotly.subplots import make_subplots # 導入用于創建子圖的函數
import plotly.express as px
import pandas as pd

二、案例:網站流量來源與用戶設備類型分析

1. 場景

假設我們需要分析一個網站的流量構成,我們關心兩個核心問題:

  • 用戶主要通過哪些來源(如搜索引擎、社交媒體、直接訪問等)訪問網站?
  • 訪問用戶主要使用哪些設備類型(如桌面電腦、移動設備、平板電腦)?

我們希望將這兩個不同視角的數據并排展示在同一張圖上,以便快速比較和理解用戶行為的全貌。

2. 數據準備

我們需要準備兩個獨立但相關的數據集:一個描述流量來源及其占比,另一個描述設備類型及其占比。

# 網站流量來源數據 (模擬)
traffic_source_data = {
    'Source': ['搜索引擎', '社交媒體', '直接訪問', '推薦鏈接', '付費廣告'],
    'Visits': [55000, 25000, 15000, 8000, 7000]
}
df_source = pd.DataFrame(traffic_source_data)
df_source['Percentage'] = (df_source['Visits'] / df_source['Visits'].sum() * 100).round(1)

# 用戶設備類型數據 (模擬)
device_type_data = {
    'Device': ['桌面電腦', '移動設備', '平板電腦'],
    'Users': [42000, 63000, 5000]
}
df_device = pd.DataFrame(device_type_data)
df_device['Percentage'] = (df_device['Users'] / df_device['Users'].sum() * 100).round(1)

print("--- 流量來源數據 ---")
print(df_source)
print("\n--- 設備類型數據 ---")
print(df_device)

我們創建了兩個獨立的 Pandas DataFrame,分別存儲流量來源和設備類型的數據,并計算了各自的百分比,為繪制餅圖做好準備。

3. 繪制餅圖

我們將使用 make_subplots 創建一個包含兩個餅圖的布局,并對每個餅圖進行精細的視覺和交互設計。

# 確保已運行上方數據準備代碼

# 創建一個 1 行 2 列的子圖布局,指定類型為 'domain' 用于餅圖
fig = make_subplots(rows=1, cols=2,
                    specs=[[{'type':'domain'}, {'type':'domain'}]], # 定義子圖類型
                    subplot_titles=("流量來源分布", "用戶設備類型")) # 設置子圖標題

# --- 第一個餅圖:流量來源 ---
fig.add_trace(go.Pie(
    labels=df_source['Source'],
    values=df_source['Visits'],
    name='來源', # 用于圖例和懸停
    hole=0.5, # 甜甜圈效果
    marker=dict(
        colors=px.colors.sequential.Blues_r, # 使用 Plotly Express 的反轉藍色調色板
        line=dict(color='#ffffff', width=2)
    ),
    textinfo='percent', # 扇區內顯示百分比
    insidetextorientatinotallow='radial',
    hovertemplate='<b>來源:</b> %{label}<br><b>訪問量:</b> %{value:,}<br><b>占比:</b> %{percent:.1%}<extra></extra>',
    pull=[0.1, 0, 0, 0, 0] # 突出顯示“搜索引擎”
), row=1, col=1) # 指定添加到第1行第1列

# --- 第二個餅圖:設備類型 ---
fig.add_trace(go.Pie(
    labels=df_device['Device'],
    values=df_device['Users'],
    name='設備',
    hole=0.5,
    marker=dict(
        colors=px.colors.sequential.Greens_r, # 使用 Plotly Express 的反轉綠色調色板
        line=dict(color='#ffffff', width=2)
    ),
    textinfo='percent',
    insidetextorientatinotallow='radial',
    hovertemplate='<b>設備:</b> %{label}<br><b>用戶數:</b> %{value:,}<br><b>占比:</b> %{percent:.1%}<extra></extra>',
    pull=[0, 0.1, 0] # 突出顯示“移動設備”
), row=1, col=2) # 指定添加到第1行第2列

# --- 整體布局與美化 ---
fig.update_layout(
    title_text='網站流量分析:來源與設備概覽', # 主標題
    title_x=0.5, # 標題居中
    # 設置統一的字體和背景
    fnotallow=dict(family="Arial, sans-serif", size=12, color='#333'),
    paper_bgcolor='rgba(248, 248, 255, 1)', # 設置淡雅的背景色 (Ghost White)
    plot_bgcolor='rgba(0,0,0,0)', # 繪圖區域背景透明
    # 統一圖例樣式 (Plotly 會自動處理多個餅圖的圖例)
    legend=dict(
        orientatinotallow="h", yanchor="bottom", y=-0.1, xanchor="center", x=0.5
    ),
    # 在甜甜圈中心添加注釋顯示總數 (可選,增加信息量)
    annotatinotallow=[
        dict(text=f'總訪問<br>{df_source["Visits"].sum():,}', x=0.18, y=0.5, font_size=16, showarrow=False),
        dict(text=f'總用戶<br>{df_device["Users"].sum():,}', x=0.82, y=0.5, font_size=16, showarrow=False)
    ],
    margin=dict(t=80, l=20, r=20, b=40) # 調整邊距給標題和圖例留出空間
)

# 顯示圖表
fig.show()

# # 或者保存為獨立的 HTML 文件
# fig.write_html("stunning_subplot_pie_charts.html")

三、總結

當需要展示同一數據的不同維度比例,或比較不同數據集的構成時,Plotly的子圖餅圖組合提供了一種強大而優雅的解決方案。通過 make_subplots 創建布局,為每個餅圖應用精美的樣式(如甜甜圈、顏色方案、描邊、注釋),并利用 Plotly 內在的交互性,我們可以將多個簡單的比例圖提升為信息豐富、視覺驚艷的數據敘事工具。

責任編輯:趙寧寧 來源: Python數智工坊
相關推薦

2010-07-01 16:48:54

UML序列圖

2024-07-26 21:35:11

2021-12-29 08:21:01

Performance優化案例工具

2011-03-31 11:15:52

網頁設計Web

2010-06-08 10:51:48

UML活動圖

2011-04-01 17:37:34

技巧

2021-01-28 07:38:29

C指針C語言應用程序

2025-04-01 08:30:00

Plotly數據可視化數據分析

2020-04-30 09:17:28

數據分析電商分析思維

2018-02-28 13:49:49

屏幕截取win 10瀏覽器

2010-09-16 15:57:00

PPPoA配置

2010-09-08 14:35:22

CSS

2022-04-20 20:30:36

可視化模塊Python

2023-04-11 07:48:32

WebGLCanvas

2024-09-09 18:18:45

2013-09-25 10:28:42

諾基亞經典

2025-03-04 00:22:31

2023-02-07 10:40:30

gRPC系統Mac

2018-12-06 11:30:42

JavaScript前端編程語言

2018-10-25 14:47:53

分析消費數據挖掘
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 99精品一区二区 | 精品久久久久久一区二区 | 亚洲精品第一国产综合野 | 精品久久一区 | 欧美日韩亚洲国产 | 国产乱码精品一品二品 | 九九视频在线观看 | 一区二区三区免费网站 | www.亚洲区| 欧美成人精品欧美一级 | 国产亚洲精品精品国产亚洲综合 | 欧美a在线 | 九九热精品免费 | 人人爽人人爽 | 韩国电影久久 | 亚洲婷婷六月天 | 欧美日一区二区 | 中文字幕在线三区 | 91av视频| 国产免费让你躁在线视频 | 中文字幕在线不卡播放 | 国产精品久久9 | 国产色婷婷久久99精品91 | 亚洲精品一二区 | 91精品一区二区三区久久久久 | 欧美精品国产一区二区 | 欧洲一级视频 | 岛国av在线免费观看 | 久久9久| 国产做爰| 欧美激情综合色综合啪啪五月 | 美女黄视频网站 | 日日天天 | 精品国产乱码久久久久久图片 | 色香蕉在线| 天天天天操 | 免费一区二区在线观看 | 97精品超碰一区二区三区 | 99伊人| 亚洲高清视频在线观看 | 国产精品自拍啪啪 |