【plt.hist绘制直方图】:从入门到精通,只需一篇文章!【Matplotlib可视化】

【📊plt.pie绘制直方图】:从入门到精通,只需一篇文章!【Matplotlib可视化】!

在这里插入图片描述

利用Matplotlib进行数据可视化示例


在这里插入图片描述

🌵文章目录🌵

  • 📈 一、引言
  • 🔍 二、plt.hist()函数基础
  • 🎨 三、plt.hist()进阶技巧
    • 1. 自定义直方图外观
    • 2. 多组数据在同一张直方图上展示
  • 📚 四、参考文档|相关链接
  • 🌳 五、结尾

📈 一、引言

  数据可视化是数据分析和机器学习领域不可或缺的一部分。其中,直方图作为一种简单而直观的数据展示方式,常被用于展示数据的分布情况。在Python的Matplotlib库中,plt.hist()函数是实现直方图绘制的强大工具。本文将从入门到精通,带领大家全面了解plt.hist()函数的使用方法和技巧。

🔍 二、plt.hist()函数基础

plt.hist()函数的基本语法如下:

plt.histhist(x, bins=None, range=None, density=False, weights=None,cumulative=False,bottom=None, histtype='bar', align='mid',orientation='vertical',rwidth=None, log=False, color=None,label=None, stacked=False,data=None)

参数解释:

  • x:需要绘制直方图的数据,可以是一维数组或列表。
  • bins:指定直方图的柱子数量或边界,默认为10。也可以是一个数组,指定每个柱子的边界。
  • color:指定柱子的颜色。
  • alpha:指定柱子的透明度,取值范围为0~1。
  • edgecolor:指定柱子的边框颜色。
  • linewidth:指定柱子的边框线宽。

💡 示例代码

import matplotlib.pyplot as plt
import numpy as np# 生成随机数据
data = np.random.randn(1000)# 绘制直方图
plt.hist(data, bins=20, color='skyblue', alpha=0.7, edgecolor='black', linewidth=1)# 设置标题和轴标签
plt.title('Histogram of Random Data')
plt.xlabel('Value')
plt.ylabel('Frequency')# 显示图形
plt.show()

  以上代码将生成一个包含20个柱子的直方图,展示随机数据的分布情况。柱子的颜色为淡蓝色,透明度为0.7,边框颜色为黑色,边框线宽为1。

🎉 效果展示

在这里插入图片描述

Fig.1 使用plt.hist()函数绘制直方图

🎨 三、plt.hist()进阶技巧

1. 自定义直方图外观

  当使用plt.hist()绘制直方图时,你可能想要进一步自定义其外观,以使其更加符合你的需求或更好地融入你的报告中。以下是一些自定义直方图外观的示例代码,并附有详细注释:

# 导入matplotlib的pyplot模块,用于绘图  
import matplotlib.pyplot as plt
# 导入numpy库,用于数值计算  
import numpy as np# 定义一个名为CustomHistogram的类,用于创建定制化的直方图
class CustomHistogram:# 初始化方法,在创建类实例时调用  def __init__(self, data, bins=30, color='skyblue', alpha=0.7, edgecolor='black', linewidth=1, title='', xlabel='',ylabel='', xlim=None, ylim=None, grid=False, save_to_file=None):# 设置数据  self.data = data# 设置直方图的柱子数量,默认为30  self.bins = bins# 设置柱子的颜色,默认为天蓝色  self.color = color# 设置柱子的透明度,默认为0.7  self.alpha = alpha# 设置柱子边缘颜色,默认为黑色  self.edgecolor = edgecolor# 设置柱子边缘线宽,默认为1  self.linewidth = linewidth# 设置图表标题  self.title = title# 设置x轴标签  self.xlabel = xlabel# 设置y轴标签  self.ylabel = ylabel# 设置x轴显示范围,默认为None,即不限制  self.xlim = xlim# 设置y轴显示范围,默认为None,即不限制  self.ylim = ylim# 设置是否显示网格线,默认为False  self.grid = grid# 设置保存图表的文件路径,默认为None,即不保存  self.save_to_file = save_to_file# 设置图例标签列表,默认为空  self.legend_labels = []# 设置字体属性,包括字体族、大小、粗细  self.font_properties = {'family': 'Arial', 'size': 12, 'weight': 'normal'}# 绘制直方图的方法def plot(self):# 绘制直方图  plt.hist(self.data, bins=self.bins, color=self.color, alpha=self.alpha, edgecolor=self.edgecolor,linewidth=self.linewidth)# 设置图表标题,并设置字体大小和粗细  plt.title(self.title, fontsize=self.font_properties['size'], fontweight='bold')# 设置x轴标签,并设置字体大小  plt.xlabel(self.xlabel, fontsize=self.font_properties['size'])# 设置y轴标签,并设置字体大小  plt.ylabel(self.ylabel, fontsize=self.font_properties['size'])# 设置x轴和y轴刻度标签的字体大小  plt.tick_params(axis='both', which='major', labelsize=self.font_properties['size'])# 如果设置了x轴显示范围,则限制x轴显示范围  if self.xlim is not None:plt.xlim(self.xlim)# 如果设置了y轴显示范围,则限制y轴显示范围if self.ylim is not None:plt.ylim(self.ylim)# 调用customize_axes方法定制坐标轴样式self.customize_axes()# 如果设置了显示网格线,则添加网格线  if self.grid:self.add_grid()# 如果设置了图例标签,则添加图例if self.legend_labels:self.add_legend(self.legend_labels)# 如果设置了保存文件路径,则保存图表到文件if self.save_to_file:self.save_chart(self.save_to_file)# 显示图表plt.show()# 定制坐标轴样式的方法def customize_axes(self):# 隐藏顶部的边框  plt.gca().spines['top'].set_visible(False)# 隐藏右侧的边框  plt.gca().spines['right'].set_visible(False)# 设置x轴刻度位置在底部  plt.gca().xaxis.set_ticks_position('bottom')# 设置y轴刻度位置在左侧  plt.gca().yaxis.set_ticks_position('left')# 添加网格线的方法def add_grid(self):# 添加y轴网格线,并设置透明度plt.grid(axis='y', alpha=0.75, linestyle='--')# 添加图例的方法def add_legend(self, labels):# 添加图例,传入图例标签列表plt.legend(labels)# 保存图表到文件的方法def save_chart(self, file_path):# 保存图表到指定文件路径plt.savefig(file_path)# 示例用法
if __name__ == "__main__":# 生成一些随机数据data = np.random.randn(1000)# 创建一个CustomHistogram实例histogram = CustomHistogram(data, bins=50, color='lightblue', alpha=0.6, edgecolor='black', linewidth=1.2,title='Customized Histogram', xlabel='Value', ylabel='Frequency',xlim=(-4, 4), ylim=(0, 60), grid=True, save_to_file='custom_histogram.png')# 绘制直方图histogram.plot()

  以上代码定义了一个名为CustomHistogram的类,用于创建并绘制定制化的直方图。类初始化时接收一系列参数,包括数据、直方图的柱子数量、颜色、透明度、边缘颜色、线宽、图表标题、轴标签、轴显示范围、是否显示网格线、保存文件路径等。类中有几个方法,分别用于绘制直方图、定制坐标轴样式、添加网格线、添加图例和保存图表到文件。

  在示例用法部分,代码生成了一些随机数据,然后创建了一个CustomHistogram的实例,并传入了一些定制参数。最后,调用plot方法绘制并显示了直方图,并且将其保存为名为custom_histogram.png的文件。

🎉 效果展示

在这里插入图片描述

Fig.2 使用plt.hist()函数自定义直方图的外观

2. 多组数据在同一张直方图上展示

  如果有多组数据需要展示,我们可以将它们绘制在同一张直方图上。通过传递多个数据序列给plt.hist()函数,并设置不同的柱子颜色,可以清晰地展示多组数据的分布情况,示例代码如下:

# 导入matplotlib.pyplot模块,用于绘图
import matplotlib.pyplot as plt
# 导入numpy模块,用于处理数组和数学运算
import numpy as np# 使用numpy生成两组随机数据
# data1是从标准正态分布中抽取的1000个随机数,并加上1作为偏移量
data1 = np.random.randn(1000) + 1
# data2是从标准正态分布中抽取的1000个随机数,并减去1作为偏移量
data2 = np.random.randn(1000) - 1# 使用plt.hist函数绘制直方图
# 参数说明:
#   - [data1, data2]:要绘制的数据,这里有两组数据
#   - bins=30:将数据分为30个直方柱
#   - color=['#add8e6', '#ffa500']:设置直方柱的颜色,分别为浅天蓝色和橙色
#   - alpha=0.7:设置直方柱的透明度
#   - label=['Data Group 1', 'Data Group 2']:为每个数据组设置标签
#   - edgecolor='black':设置直方柱的边缘颜色为黑色
#   - linewidth=1:设置直方柱的边缘线宽
plt.hist([data1, data2], bins=30, color=['#add8e6', '#ffa500'], alpha=0.7, label=['Data Group 1', 'Data Group 2'],edgecolor='black', linewidth=1)# 添加网格线到图表上,仅对y轴添加网格线,并设置透明度为0.75
plt.grid(axis='y', alpha=0.75)# 设置x轴的标签,标签内容为'Value',字体大小为12,颜色为暗红色
plt.xlabel('Value', fontsize=12, color='darkred')
# 设置y轴的标签,标签内容为'Frequency',字体大小为12,颜色为暗红色
plt.ylabel('Frequency', fontsize=12, color='darkred')# 设置图表的标题,标题内容为'Histogram Comparison of Two Data Groups',字体大小为14,颜色为暗红色
plt.title('Histogram Comparison of Two Data Groups', fontsize=14, color='darkred')# 计算两组数据的均值和中位数
mean1, median1 = np.mean(data1), np.median(data1)
mean2, median2 = np.mean(data2), np.median(data2)# 在图表上添加文本,显示第一组数据的统计信息
# 参数说明:
#   - 0.75, 0.95:文本在图上的位置
#   - f'Data Group 1:\nMean: {mean1:.2f}\nMedian: {median1:.2f}':要显示的文本内容,包括均值和中位数
#   - transform=plt.gca().transAxes:设置文本的位置参考坐标系为图的相对坐标系
#   - fontsize=10:设置文本字体大小
#   - verticalalignment='top':设置文本垂直对齐方式为顶部对齐
#   - bbox:设置文本的边框样式和颜色
plt.text(0.75, 0.95, f'Data Group 1:\nMean: {mean1:.2f}\nMedian: {median1:.2f}',transform=plt.gca().transAxes, fontsize=10, verticalalignment='top',bbox=dict(boxstyle='round', facecolor='lightblue', alpha=0.5))# 在图表上添加文本,显示第二组数据的统计信息
# 参数与上面类似,只是位置和文本内容有所不同
plt.text(0.75, 0.70, f'Data Group 2:\nMean: {mean2:.2f}\nMedian: {median2:.2f}',transform=plt.gca().transAxes, fontsize=10, verticalalignment='top',bbox=dict(boxstyle='round', facecolor='lightyellow', alpha=0.5))# 调整图例的位置到图表的左上角
plt.legend(loc='upper left')# 显示图表
plt.show()# 将图表保存为名为'histogram_comparison.png'的图片文件,并设置分辨率为300dpi
plt.savefig('histogram_comparison.png', dpi=300)

🎉 效果展示

在这里插入图片描述

Fig.3 使用plt.hist()将多组数据在同一张直方图上展示

📚 四、参考文档|相关链接

  1. 专栏:Matplotlib之旅:零基础精通数据可视化(希望可以帮助你快速上手Matplotlib)
  2. Matplotlib初探:认识数据可视化与Matplotlib
  3. 数据分析利器对决:Matplotlib中的MATLAB风格与面向对象风格,你选谁?
  4. 【plt.colorbar添加颜色条】:从入门到精通,只需一篇文章!【Matplotlib】
  5. 【plt.bar绘制条形图or柱状图】:从入门到精通,只需一篇文章!【Matplotlib可视化】
  6. 【plt.pie绘制饼图】:从入门到精通,只需一篇文章!【Matplotlib可视化】
  7. 【plt.imshow显示图像】:从入门到精通,只需一篇文章!【Matplotlib】

🌳 五、结尾

  亲爱的读者,感谢您每一次停留和阅读,这是对我们最大的支持和鼓励!🙏在茫茫网海中,您的关注让我们深感荣幸。您的独到见解和建议,如明灯照亮我们前行的道路。🌟若在阅读中有所收获,一个赞或收藏,对我们意义重大。

  我们承诺,会不断自我挑战,为您呈现更精彩的内容。📚有任何疑问或建议,欢迎在评论区畅所欲言,我们时刻倾听。💬让我们携手在知识的海洋中航行,共同成长,共创辉煌!🌱🌳感谢您的厚爱与支持,期待与您共同书写精彩篇章!

  您的点赞👍、收藏🌟、评论💬和关注💖,是我们前行的最大动力!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/479104.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端仔浅浅复习一下服务器的购买与使用

最近想买个服务器搭建个博客玩玩,所以就重新熟悉一下,从0到1,从购买服务器到使用的整个流程。 产品选择 阿里云和腾讯云两个大头居多,两个都有新人首购优化,100以内一年,对比一下看哪边的优惠力度大就选哪…

AT24C02(I2C总线)通信的学习

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、存储器介绍二、AT24C02芯片二、I2C总线I2C电路规范I2C时序结构I2C数据帧AT24C02数据帧 总结 前言 学习AT24C02(I2C总线)芯片 一、存储器介绍 RAM&#xf…

自适应网站建站源码系统 带完整的安装代码包以及搭建教程

在当今数字化时代,拥有一个功能全面且能够适应不同设备的网站对于企业和个人来说至关重要。罗峰给大家分享一款全新的自适应网站建站源码系统,它不仅提供了完整的安装代码包,还附带了详细的搭建教程,帮助用户轻松构建出具有响应式…

解决kkFileView4.4.0版本pdf、word不能预览问题

这里使用的是http下载流url预览&#xff0c;遇到的问题。 官方使用指南&#xff1a;kkFileView - 在线文件预览 1 前端测试代码 1.1 官方示例代码 1.2 本人测试代码 注意&#xff1a;要给预览文件的url进行编码encodeURIComponent(Base64.encode(previewUrl))。 <!DOCTYP…

多线程案例

&#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f4d5;格言&#xff1a;那些在暗处执拗生长的花&#xff0c;终有一日会馥郁传香欢迎大家&#x1f44d;点赞✍评论⭐收藏 目录 单例模式 饿汉模式 懒汉模式 阻塞队列 生产者-消费者模型意义 定时器 单例模式 单例模式就…

Linux网络编程——序列反序列化

文章目录 0. 前言1. 认识协议2. 序列号与反序列化3. 自定义协议——网络计算器4. json 本章Gitee仓库&#xff1a;序列反序列化 0. 前言 tcp是面向字节流的&#xff0c;但是如何保证读取的数据是一个完整的报文呢&#xff1f; 管道也是面向字节流&#xff0c;写端写了一大堆的…

Redis篇----第九篇

系列文章目录 文章目录 系列文章目录前言一、说说 Redis 哈希槽的概念?二、Redis 集群的主从复制模型是怎样的?三、Redis 集群会有写操作丢失吗?为什么?四、Redis 集群之间是如何复制的?五、Redis 集群最大节点个数是多少?前言 前些天发现了一个巨牛的人工智能学习网站,…

前端新手Vue3+Vite+Ts+Pinia+Sass项目指北系列文章 —— 第十二章 常用工具函数 (Utils配置)

前言 在项目开发中&#xff0c;我们经常会使用一些工具函数&#xff0c;也经常会用到例如loadsh等工具库&#xff0c;但是这些工具库的体积往往比较大&#xff0c;如果项目本身已经引入了这些工具库&#xff0c;那么我们就没有必要再引入一次&#xff0c;所以我们需要自己封装…

基于WOA优化的Bi-LSTM多输入回归预测(Matlab)鲸鱼算法优化双向长短期神经网络回归预测

目录 一、程序及算法内容介绍&#xff1a; 基本内容&#xff1a; 亮点与优势&#xff1a; 二、实际运行效果&#xff1a; 三、算法介绍&#xff1a; 鲸鱼优化算法&#xff08;WOA&#xff09;&#xff1a; 双向长短期神经网络&#xff08;Bi-LSTM&#xff09;&#xff1a…

PCIe学习笔记(2)错误处理和AER/DPC功能

文章目录 PCIe ErrorAER (Advanced Error Reporting)DPC (Downstream Port Containment) 处理器上错误通常可分为detected和undetected error。Undetected errors可能变得良性(benign)&#xff0c;也可能导致系统故障如silent data corruptions (SDC)。Detected errors则又可分…

springboot当中使用EMQX(MQTT协议)

本篇博客主要围绕EMQX是什么&#xff1f;、能干什么&#xff1f;、怎么用&#xff1f; 三点来进行整理。 1、MQTT协议 1.1、MQTT简介 在了解EMQX前首先了解一下MQTT协议&#xff0c;MQTT 全称为 Message Queuing Telemetry Transport&#xff08;消息队列遥测传输&#xff0…

web基础及http协议 (二) apache

一、httpd 安装组成 http 服务基于 C/S 结构 1 .常见http 服务器程序 httpd apache&#xff0c;存在C10K&#xff08;10K connections&#xff09;问题 nginx 解决C10K问题lighttpd IIS .asp 应用程序服务器 tomcat .jsp 应用程序服务器 jetty 开源的servlet容器&#xf…