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

Python讀取Excel繪制直方圖的方法

 更新時間:2025年04月22日 08:46:58   投稿:mrr  
這篇文章主要介紹了Python讀取Excel繪制直方圖,以下將詳細(xì)介紹如何使用 Python 的?pyecharts、matplotlib?和?seaborn?三個庫從 Excel 中讀取數(shù)據(jù)并繪制直方圖(Histogram),需要的朋友可以參考下

以下將詳細(xì)介紹如何使用 Python 的 pyecharts、matplotlib 和 seaborn 三個庫從 Excel 中讀取數(shù)據(jù)并繪制直方圖(Histogram)。直方圖用于展示數(shù)據(jù)分布,核心是統(tǒng)計不同區(qū)間的頻數(shù)或頻率。每個庫的代碼示例均包含核心類、函數(shù)和屬性的詳細(xì)說明。

1. 使用 pyecharts 繪制直方圖

pyecharts 是基于 ECharts 的交互式可視化庫,但需手動計算直方圖的頻數(shù)分布(因無內(nèi)置直方圖函數(shù))。

代碼示例:

import pandas as pd
import numpy as np
from pyecharts.charts import Bar
from pyecharts import options as opts
# 讀取Excel數(shù)據(jù)
df = pd.read_excel("data.xlsx")
data = df["數(shù)值列"].tolist()  # 假設(shè)數(shù)據(jù)列名為"數(shù)值列"
# 計算直方圖的區(qū)間和頻數(shù)
counts, bins = np.histogram(data, bins=10)  # 分10個區(qū)間
x_labels = [f"{bins[i]:.1f}-{bins[i+1]:.1f}" for i in range(len(bins)-1)]
# 創(chuàng)建柱狀圖(模擬直方圖)
bar = Bar()
bar.add_xaxis(x_labels)
bar.add_yaxis("頻數(shù)", counts.tolist())
# 配置全局選項(xiàng)
bar.set_global_opts(
    title_opts=opts.TitleOpts(title="數(shù)值分布直方圖"),
    xaxis_opts=opts.AxisOpts(name="區(qū)間"),
    yaxis_opts=opts.AxisOpts(name="頻數(shù)"),
    toolbox_opts=opts.ToolboxOpts()
)
# 渲染為HTML文件
bar.render("pyecharts_histogram.html")

核心類與函數(shù):

  • Bar(): 柱狀圖對象,用于模擬直方圖。
  • np.histogram(): 計算直方圖頻數(shù)和區(qū)間(bins 指定區(qū)間數(shù)量)。
  • add_xaxis()/add_yaxis(): 添加 X/Y 軸數(shù)據(jù)。
  • set_global_opts(): 配置標(biāo)題、坐標(biāo)軸名稱等。

2. 使用 matplotlib 繪制直方圖

matplotlib 是基礎(chǔ)繪圖庫,內(nèi)置 hist() 函數(shù)直接繪制直方圖。

代碼示例:

import pandas as pd
import matplotlib.pyplot as plt
# 讀取Excel數(shù)據(jù)
df = pd.read_excel("data.xlsx")
data = df["數(shù)值列"]
# 創(chuàng)建畫布和坐標(biāo)系
fig, ax = plt.subplots(figsize=(10, 6))
# 繪制直方圖
ax.hist(
    data, 
    bins=10,              # 區(qū)間數(shù)量
    color="skyblue",      # 顏色
    edgecolor="black",    # 邊框顏色
    alpha=0.7,            # 透明度
    density=False         # False顯示頻數(shù),True顯示頻率
)
# 添加標(biāo)題和標(biāo)簽
ax.set_title("數(shù)值分布直方圖", fontsize=14)
ax.set_xlabel("數(shù)值范圍", fontsize=12)
ax.set_ylabel("頻數(shù)", fontsize=12)
ax.grid(axis="y", linestyle="--")  # 顯示橫向網(wǎng)格線
# 顯示圖表
plt.tight_layout()
plt.savefig("matplotlib_histogram.png")
plt.show()

核心函數(shù)與參數(shù):

  • ax.hist(): 直方圖繪制函數(shù)。
    • bins: 區(qū)間數(shù)量或具體邊界值(如 bins=[0, 10, 20])。
    • color/edgecolor: 填充色和邊框顏色。
    • alpha: 透明度(0-1)。
    • density: 是否顯示頻率(歸一化)。
  • ax.set_title()/ax.set_xlabel()/ax.set_ylabel(): 標(biāo)題和坐標(biāo)軸標(biāo)簽。

3. 使用 seaborn 繪制直方圖

seaborn 基于 matplotlib,提供更簡潔的語法和統(tǒng)計功能(如核密度估計)。

代碼示例:

import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt
# 讀取Excel數(shù)據(jù)
df = pd.read_excel("data.xlsx")
data = df["數(shù)值列"]
# 設(shè)置主題
sns.set_theme(style="whitegrid", font="SimHei")  # 中文需指定字體
# 創(chuàng)建直方圖
plt.figure(figsize=(10, 6))
ax = sns.histplot(
    data,
    bins=10,                # 區(qū)間數(shù)量
    kde=True,               # 顯示核密度曲線
    color="skyblue",        # 顏色
    edgecolor="black",      # 邊框顏色
    stat="count"            # 統(tǒng)計類型(默認(rèn)count,可選"density")
)
# 添加標(biāo)題和標(biāo)簽
ax.set_title("數(shù)值分布直方圖(帶核密度估計)", fontsize=14)
ax.set_xlabel("數(shù)值范圍", fontsize=12)
ax.set_ylabel("頻數(shù)", fontsize=12)
# 顯示圖表
plt.tight_layout()
plt.savefig("seaborn_histogram.png")
plt.show()

核心函數(shù)與參數(shù):

  • sns.histplot(): 直方圖繪制函數(shù)。
    • kde: 是否顯示核密度估計曲線(默認(rèn) False)。
    • stat: 統(tǒng)計類型("count" 頻數(shù),"density" 頻率,"percent" 百分比)。
    • bins/color/edgecolor: 同 matplotlib。
  • sns.set_theme(): 設(shè)置主題樣式(如 whitegriddarkgrid)。

對比總結(jié)

特點(diǎn)適用場景
pyecharts需手動計算頻數(shù),生成交互式圖表需要網(wǎng)頁嵌入或動態(tài)交互
matplotlib直接繪制,高度可定制需要精細(xì)控制圖表細(xì)節(jié)
seaborn語法簡潔,支持核密度估計快速生成統(tǒng)計圖表

注意事項(xiàng)

  • 數(shù)據(jù)預(yù)處理:確保 Excel 中的目標(biāo)列是數(shù)值類型(非字符串)。
  • 區(qū)間劃分:調(diào)整 bins 參數(shù)優(yōu)化數(shù)據(jù)分布展示(如 bins=20 增加細(xì)節(jié))。
  • 交互性pyecharts 適合生成 HTML 文件,而 matplotlib/seaborn 適合靜態(tài)圖片。

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

相關(guān)文章

最新評論