【数据分析】描述性统计分析 - 直方图

一、什么是直方图

  • 由一批长方形构成,通过长方形的面积或高度来代表对应组在数据中所占的比例。
  • 用长方形的面积代表对应组的频数与组距的比时,则称为频率分布直方图;
  • 当用长方形的高代表对应组的频数时,则称为频数分布直方图
  • 但严格统计意义上的直方图都是指频率分布直方图 ,而且统计意义上的直方图没有纵向刻度

二、绘制直方图

三、Python 绘制直方图

1、使用 pandasnumpymatplotlib绘制直方图

python 复制代码
# Using pandas, numpy, matplotlib to draw histograms
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib

# set the backend of matplotlib to TkAgg
matplotlib.use('TkAgg')

data = pd.DataFrame({
    # Generate 1000 random numbers with a standard normal distribution
    'Values': pd.Series(np.random.randn(1000))
})

# Draw a histogram
data['Values'].plot.hist(bins=30, alpha=0.5, color='lightblue',
                        edgecolor='darkblue')


# set chart title and axis labels
plt.title('Histogram of Values')
plt.xlabel('Value')
plt.ylabel('Frequency')

# display chart
plt.show()

2、使用 pandasnumpymatplotlib绘制直方图

python 复制代码
# Using plotly.express to draw histograms
import plotly.express as px
import pandas as pd
import numpy as np
# data = [1, 2, 3, 4, 5, 6, 7, 8, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17]

data = pd.DataFrame({
    'Values': pd.Series(np.random.randn(1000))
})
# Nbins defines the number of boxes in the histogram
fig = px.histogram(data, nbins=80,
                   color_discrete_sequence=['blue'],
                   labels={'Values': 'Value'},
                   title='Histogram of Values',
                   # marginal="box"
                   )

fig.update_traces(
    marker=dict(
        color='lightblue',
        opacity=0.75,
        line=dict(
            color='darkblue',
            width=1
        )
    )
)

# display chart
fig.show()

3、使用 pandasnumpydash****和 plotly.express绘制直方图

python 复制代码
# Using dash, plotly.express to draw histogram
import dash
import numpy as np
import pandas as pd
from dash import html, dcc
import plotly.express as px

# create a dash application
app = dash.Dash(__name__)

# create as list
# data = [1, 2, 2, 2, 2, 3, 4, 5, 5, 5, 6, 7, 8, 8, 8, 9, 9, 10, 10, 10, 11, 12, 12, 12, 13, 14, 12, 15, 15, 16, 17, 18, 18, 18, 19, 19, 20, 20, 20]
data = pd.DataFrame({
    'Values': pd.Series(np.random.randn(1000))
})

# use plotly.express to draw histogram
fig = px.histogram(data, nbins=60,
                    color_discrete_sequence=['blue'],
                    labels={'Values': 'Value'},
                    title='Histogram of Values',
                    # marginal="box",
                    )

fig.update_traces(
    marker=dict(
        color='lightblue',
        opacity=0.75,
        line=dict(
            color='darkblue',
            width=1
        )
    )
)

# define application layout
app.layout = html.Div([
    html.H1('Dash Histogram Example'),
    dcc.Graph(figure=fig)
])

# run the application
if __name__ == '__main__':
    app.run_server(debug=True)
相关推荐
QDYOKR1682 小时前
OKR管理系统怎么选?2026主流OKR工具深度解析
大数据·人工智能·信息可视化·数据挖掘·数据分析
2601_954971133 小时前
经济学专业考CDA数据分析师证书值不值?对求职帮助到底有多大
数据挖掘
PaperData20 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF
数据库·人工智能·数据分析·经管
小王毕业啦20 小时前
(1990-2024年)个股交易活跃度、个股换手率
大数据·人工智能·数据挖掘·数据分析·区块链·社科数据
AI科技星21 小时前
光子本源三元结构定理(《全域数学·物理原本》)【乖乖数学】
人工智能·机器学习·数学建模·数据挖掘·agi
小王毕业啦1 天前
2013-2023年 银行风险资产占比数据
大数据·人工智能·数据挖掘·数据分析·社科数据
云渊未归061 天前
Python获取GitCode项目信息
python·数据分析·开源·网络爬虫·gitcode
郝学胜-神的一滴1 天前
深度学习损失函数:从原理到实战之 Smooth L1 Loss
人工智能·pytorch·python·深度学习·机器学习·数据挖掘
高洁011 天前
AI项目管理实战:从开发到交付的全流程管控
深度学习·机器学习·数据挖掘·transformer·知识图谱
YJlio1 天前
2026年5月5日60秒读懂世界:五一档票房、油价调整、汤姆斯杯夺冠与全球风险观察
数据分析·django·飞书·仪表盘·多维表格·图表联动