matplotlib科研绘图之折线图、柱状图、散点图、误差棒

 matplotlib折线图例子1

# -*- coding: utf-8 -*-
# @Time    : 2023/12/19 10:56
# @Author  : 长沙有肥鱼
# @FileName: 21.py
# @Software: PyCharm
# @Blog    : https://blog.csdn.net/weixin_53660567?spm=1010.2135.3001.5343# 导入Matplotlib库
import matplotlib
import matplotlib.pyplot as plt# 设置中文显示
matplotlib.rcParams['font.sans-serif'] = ['SimSun']  # 用宋体显示中文# 数据
x = [25, 27.5, 31.5, 34]
y1 = [1.138, 1.242, 1.345, 1.428]
y2 = [1.260, 1.363, 1.465, 1.562]
y3 = [1.154, 1.271, 1.393, 1.464]
y4 = [1.170, 1.253, 1.373, 1.454]
y5 = [1.230, 1.313, 1.404, 1.504]# 绘制折线图,每个数据集使用不同的标记、颜色和线型
plt.plot(x, y1, marker='*', ms=13, label="case 1", markerfacecolor='#FF0000',markeredgecolor='#FF0000', linestyle='-', linewidth=2.5, color='#FF0000')
plt.plot(x, y2, marker='D', ms=9, label="case 2", markerfacecolor='#FF9900',markeredgecolor='#FF9900', linestyle='-', linewidth=2.5, color='#FF9900')
plt.plot(x, y3, marker='d', ms=10, label="case 3", markerfacecolor='#0000FF',markeredgecolor='#0000FF', linestyle='-', linewidth=2.5, color='#0000FF')
plt.plot(x, y4, marker='v', ms=10, label="case 4", markerfacecolor='#00FF00',markeredgecolor='#00FF00', linestyle='--', linewidth=2.5, color='#00FF00')
plt.plot(x, y5, marker='o', ms=10, label="case 5", markerfacecolor='#FF00FF',markeredgecolor='#FF00FF', linestyle='-.', linewidth=2.5, color='#FF00FF')# 设置x轴和y轴标签
plt.xticks(rotation=0, fontproperties='Times New Roman', fontsize=12)  # rotation=45
plt.yticks(rotation=0, fontproperties='Times New Roman', fontsize=12)
plt.xlabel("电压", fontsize=18)
plt.ylabel("电流", fontsize=18)# 设置图表标题
plt.title("高压电站电压与电流的关系", fontsize=18)# 更新图例字体大小和样式
plt.rcParams.update({'font.size': 15})
plt.legend(loc="upper left", prop='Times New Roman', fontsize=25, ncols=2, edgecolor='#C4C4C4',facecolor='white', fancybox=True, title_fontsize=25)# 保存图表为图片文件
plt.savefig("21.png", dpi=1800)# 显示图表
plt.show()

 matplotlib折线图例子2

import matplotlib.pyplot as plt
# import numpy as npy1 = [2, 3, 4, 4, 5, 6, 5, 4, 3, 3, 1, 1, 1]
y2 = [3, 2, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1]
x = range(18, 31)# 设置图形大小
plt.figure(figsize=(20, 7))plt.plot(x, y1, label="自己本年度谈的对象数量", marker='D', markersize=10, markerfacecolor='cyan',markeredgecolor='cyan', color='cyan', linestyle='-', linewidth=3)
plt.plot(x, y2, label="同桌本年度谈的对象数量", marker='*', markersize=15, markerfacecolor='#FF0000',markeredgecolor='#FF0000', color='#FF0000', linestyle='--', linewidth=3)# 设置x轴刻度
_xticks_labels = ["{}岁".format(i) for i in x]
plt.xticks(x, _xticks_labels, fontproperties='SimSun', fontsize=22)
plt.yticks(range(0, 9), fontproperties='Times New Roman', fontsize=22)# 绘制网格
plt.grid(alpha=0.2)
plt.rcParams.update({'font.size': 20})  # 图例大小设置
plt.legend(prop='SimSun', fontsize=25, loc='best',  ncols=2, edgecolor='#C4C4C4',facecolor='white', fancybox=False, title_fontsize=25)  # 图例设置
plt.xlabel("年龄", fontsize=25, fontproperties='SimSun')  # x轴标签
plt.ylabel("对象数量", fontsize=25, fontproperties='SimSun')  # y轴标签# 设置图表标题
plt.title("年龄与对象数量的关系", fontproperties='SimSun', fontsize=30)
# 显示图形
plt.savefig("D://matplotlib画图//学习//10.png", dpi=1200)
plt.show()

 marker设置

.:点(point marker)
,:像素点(pixel marker)
1:(tri_down marker)
2:(tri_up marker)
3:(tri_left marker)
4:(tri_right marker)
o:圆形(circle marker)
v:朝下三角形(triangle_down marker)
+:+号标记(plus marker)
x:x号标记(x marker)
D:菱形(diamond marker)
d:小型菱形(thin_diamond marker)
s:正方形(square marker)
p:五边星(pentagon marker)
*:星型(star marker)
h:1号六角形(hexagon1 marker)
H:2号六角形(hexagon2 marker)
|:垂直线形(vline marker)
_:水平线形(hline marker)
^:朝上三角形(triangle_up marker)
<:朝左三角形(triangle_left marker)
>:朝右三角形(triangle_right marker)

 color设置

legend()设置

def __init__(self, parent, handles, labels,*,loc=None,numpoints=None,      # 图例线中的点数markerscale=None,    # 图例标记相对于原始标记的相对大小markerfirst=True,    # 图例标记和标签的左/右排序reverse=False,       # 图例标记和标签的反向排序scatterpoints=None,  # 散射点数量scatteryoffsets=None,prop=None,           # 图例文本的属性fontsize=None,       # 关键字直接设置字体大小labelcolor=None,     # 关键字来设置文本颜色# 间距&填充定义为字体大小的一小部分borderpad=None,      # 图例边框内的空白labelspacing=None,   # 图例条目之间的垂直间距handlelength=None,   # 图例手柄的长度handleheight=None,   # 图例手柄的高度handletextpad=None,  # 图例手柄和文本之间的填充borderaxespad=None,  # 轴和图例边框之间的填充columnspacing=None,  # 柱间距ncols=1,     # 列数mode=None,  # 列的水平分布:无或“展开”fancybox=None,  # True:花式框,False:圆形框,None:rcParamshadow=None,title=None,           # 图例标题title_fontsize=None,  # 图例标题字体大小framealpha=None,      # 设置帧alphaedgecolor=None,       # 边框补丁边缘颜色facecolor=None,       # 框架补丁面颜色bbox_to_anchor=None,  # 图例将锚定到的bboxbbox_transform=None,  # 为bbox转换frameon=None,         # 并条机handler_map=None,title_fontproperties=None,  # 图例标题的属性alignment="center",       # 控制图例框内的对齐ncol=1,  # ncols的同义词(向后兼容性)draggable=False  # 是否可以用鼠标拖动图例
):

  matplotlib条形图例子1

import matplotlib.pyplot as plta = ["战狼2", "速度与激情8", "功夫瑜伽", "西游伏妖篇", "变形金刚5:最后的骑士","摔跤吧!爸爸", "加勒比海盗5:死无对证", "金刚:骷髅岛", "极限特工:终极回归","生化危机6:终章", "乘风破浪", "神偷奶爸3", "智取威虎山", "大闹天竺","金刚狼3:殊死一战", "蜘蛛侠:英雄归来", "悟空传", "银河护卫队2","情圣", "新木乃伊"]
b = [56.01, 26.94, 17.53, 16.49, 15.45, 12.96, 11.8, 11.61,11.28, 11.12, 10.49, 10.3, 8.75, 7.55, 7.32, 6.99,6.88, 6.86, 6.58, 6.23]plt.figure(figsize=(20, 10))# 绘制条形图
plt.barh(range(len(a)), b, height=0.6, color='#FF6600')
plt.xticks(fontproperties='Times New Roman', fontsize=25)
plt.yticks(range(len(a)), a, fontproperties='SimSun', fontsize=15, rotation=45)
plt.xlabel("票房", fontsize=25, fontproperties='SimSun')  # x轴标签
plt.ylabel("电影名称", fontsize=25, fontproperties='SimSun')  # y轴标签# 设置图表标题
plt.title("某年度电影票房排行榜", fontproperties='SimSun', fontsize=30)
# plt.legend(loc="upper left", prop='Times New Roman', fontsize=25, ncols=2, edgecolor='#C4C4C4',
#            facecolor='white', fancybox=True, title_fontsize=25)
plt.savefig("./14.png", dpi=1500)  # 保存图片
plt.show()

  matplotlib条形图例子2

import matplotlib.pyplot as plta = ["北京各区房价", "上海各区房价", "深圳各区房价", "鹤岗各区房价"]
b1 = [121000, 140885, 71219, 1948]
b2 = [148833, 116770, 106410, 2518]
b3 = [96384, 126999, 102957, 1720]
b4 = [88704, 121743, 58809, 1554]
b5 = [70884, 117869, 49275, 1239]
bar_width = 0.1x1 = list(range(len(a)))
x2 = [i + bar_width for i in x1]
x3 = [i + bar_width * 2 for i in x1]
x4 = [i + bar_width * 3 for i in x1]
x5 = [i + bar_width * 4 for i in x1]plt.figure(figsize=(20, 8))
plt.bar(range(len(a)), b1, width=bar_width, label="区1房价", color='#4A7EBB')
plt.bar(x2, b2, width=bar_width, label="区2房价", color='#FF6600')
plt.bar(x3, b3, width=0.1, label="区3房价", color='#00FF00')
plt.bar(x4, b4, width=0.1, label="区4房价", color='#C760FF')
plt.bar(x5, b5, width=0.1, label="区5房价", color='#02CCFE')plt.rcParams.update({'font.size': 18})
plt.legend(prop='SimSun', fontsize=25)
plt.grid(alpha=0.5)
plt.xticks(x3, a, fontproperties='SimSun', fontsize=20)
plt.yticks(fontproperties='Times New Roman', fontsize=20)
plt.savefig("./15.png", dpi=1200)
plt.show()

matplotlib散点图例子

import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimSun']
y1 = [11, 17, 16, 11, 12, 11, 12, 6, 6, 7, 8, 9, 12, 15, 14, 17,18, 21, 16, 17, 20, 14, 15, 15, 15, 19, 21, 22, 22, 22, 23]
y2 = [26, 26, 28, 19, 21, 17, 16, 19, 18, 20, 20, 19, 22, 23, 17,20, 21, 20, 22, 15, 11, 15, 5, 13, 17, 10, 11, 13, 12, 13, 6]
x1 = range(1, 32)
x2 = range(51, 82)# 设置图形大小
plt.figure(figsize=(20, 13))plt.scatter(x1, y1, label="3月份", linewidth=10, color='#00FF00')
plt.scatter(x2, y2, label="10月份", linewidth=10, color='r')# 调整x轴的刻度
_x = list(x1) + list(x2)
_xticks_labels = ["3月{}日".format(i) for i in x1]
_xticks_labels += ["10月{}日".format(i) for i in x2]plt.xticks(_x[::3], _xticks_labels[::3], fontproperties='SimSun', rotation=45, fontsize=20)
plt.yticks(fontproperties='SimSun', fontsize=20)# 添加图例
plt.legend(loc='upper left', fontsize=25)
# plt.grid(alpha=0.2)
# 添加描述信息
plt.xlabel("时间", fontproperties='SimSun', fontsize=25)
plt.ylabel("温度", fontproperties='SimSun', fontsize=25)
plt.title("气温与月份之间的关系", fontproperties='SimSun', fontsize=30, fontweight='bold')plt.savefig("./12.png", dpi=1200)
plt.show()

 matplotlib误差棒例子1

import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.family'] = 'Times New Roman'
# 平均收入, 波动范围
money = [20, 25, 18, 22, 17, 15]
tolerance_p = [2, 1, 3, 4, 2, 1]index = np.arange(len(money))
width = 0.4
cities = ['北京', '上海', '广州', '深圳', '西安', '武汉']
# 绘制房价柱状图和收入柱状图
# yerr用来指定误差范围, 与结果图中的误差线对应
err_attr = {"elinewidth": 2, "ecolor": "black", "capsize": 5}  # 误差棒的属性bar_money = plt.bar(index, money, width, color=['#66FF33', '#00FFFF', '#FF00FF', '#FF6600', '#9900CC', '#0000FF'],yerr=tolerance_p, error_kw=err_attr)plt.xlabel('城市名称', fontproperties='simsun', fontsize=16)
plt.ylabel('金额(万元)', fontproperties='simsun', fontsize=16)
plt.title('收入与偏差关系', fontproperties='simsun', fontsize=22)
plt.xticks(index, cities, fontproperties='simsun', fontsize=15)# 创建图例
def add_text(bars, tol):for index, bar in enumerate(bars):x = bar.get_x() + width/2h = bar.get_height()# 在每个柱的误差线上下两侧显示文本, ha、va表示水平、垂直对其方式plt.text(x, h+tol[index], str(h+tol[index]), color='k', ha='center', va='bottom', fontsize=9)plt.text(x, h-tol[index]-1, str(h-tol[index]), color='w', ha='center', va='bottom', fontsize=9)add_text(bar_money, tolerance_p)
plt.savefig("D://matplotlib画图//学习//8_1.png", dpi=1800)
plt.show()

 matplotlib误差棒例子2

import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['Times New Roman']
x = (25, 26, 27, 28, 29)  # 年龄(岁)
y = (25, 26, 28, 30, 35)  # 年收入(万元)
y_offset = (3, 1, 2, 3, 3)  # 收入波动范围# elinewidth=2(误差棒中间线的宽度)  capthick=1(上下两条横线的厚度)  capsize=5(上下两条横线的长度)
plt.errorbar(x, y, yerr=y_offset, capsize=5, capthick=1, linestyle='--', marker='*', markersize=15,color='#FF0000', linewidth=3, ecolor='#00FF00', elinewidth=2, barsabove=False)# 在误差线上下两侧显示文本,ha、va表示水平、垂直对齐方式
for i, (xi, yi, offset) in enumerate(zip(x, y, y_offset)):plt.text(xi, yi + offset + 0.1, f'{yi + offset}', ha='center', va='bottom', fontsize=10, color='black')plt.text(xi, yi - offset - 0.3, f'{yi - offset}', ha='center', va='top', fontsize=10, color='black')plt.xticks(fontsize=15)
plt.yticks(fontsize=15)
plt.xlabel('年龄(岁)', fontproperties='SimSun', fontsize=15)
plt.ylabel('年收入(万元)', fontproperties='SimSun', fontsize=15)
plt.title('年收入与年龄关系图', fontproperties='SimSun', fontsize=15)
plt.savefig("D://matplotlib画图//学习//9.png", dpi=1800)
plt.show()

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

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

相关文章

中低压MOS 适用于电子烟等产品—— 较小的开关损耗 过流能力好

工作原理&#xff1a; 当用户在吸嘴处抽吸时&#xff0c;气流经过进气孔&#xff0c;穿 过电路板上方的咪头&#xff0c;咪头即产生电信号&#xff0c;驱 动芯片板&#xff0c;让电池供电给雾化芯&#xff0c;雾化芯中的 发热丝将电能转化成热能&#xff0c;当温度达到…

github订阅充值

一、前言 GitHub是全球最大的面向开源及私有软件项目托管平台之一。它提供了一个基于Git的托管服务&#xff0c;使得用户可以轻松地在互联网上存储、共享和管理其代码仓库。 二、GitHub的主要特点 开放性和协作性&#xff1a;GitHub是面向开发者和开源社区的&#xff0c;其平…

ios微信小程序table头部与左侧固定双重滚动会抖动的坑,解决思路

正常情况是左右滑动时&#xff0c;左侧固定不动&#xff0c;上下滑动时表头不动&#xff1b;而且需求不是完整页面滚动。而是单独这个表滚动&#xff1b; 第一个坑是他有一个ios自带的橡胶上下回弹效果。导致滚动时整个表都跟着回弹&#xff1b; 这个是很好解决。微信开发官网…

浏览器原理篇—渲染原理

目录导航 为什么要学习浏览器的渲染原理浏览器的渲染流程浏览器的渲染阻塞浏览器的渲染优化 为什么要学习浏览器的渲染原理&#xff1f; 知识深度挖掘&#xff1a; 帮助更好地理解前端性能优化。从而对实现效果进行针对性优化。如&#xff1a;**回流和重绘 **渲染机制。帮助…

公共字段自动填充——后端

场景&#xff1a;当处理一些请求时&#xff0c;会重复的对数据库的某些字段进行赋值&#xff08;如&#xff1a;在插入和更新某个物品时&#xff0c;需要更新该物品的更新时间和更新者的信息&#xff09;&#xff0c;这样会导致代码冗余。 如&#xff1a; 思路&#xff1a; 自…

得物-Golang-记一次线上服务的内存泄露排查

1.出现内存泄漏 1.1 事发现场 在风和日丽的一天&#xff0c;本人正看着需求、敲着代码&#xff0c;展望美好的未来。突然收到一条内存使用率过高的告警。 1.2 证人证词 告警的这个项目&#xff0c;老代码是python的&#xff0c;最近一直在go化。随着go化率不断上升&#xff…

phpmyadmin4.8.1远程文件包含漏洞 [GWCTF 2019]我有一个数据库1

打开题目 我们用dirsearch扫描一下后台看看 扫描结果如下 我们访问一下robots.txt看看&#xff0c;提示有phpinfo.php 那我们访问一下phpinfo.php 发现没有任何信息后我们转去看看phpmyadmin看看 成功访问到页面 在这里我们看到phpmyadmin的版本号是4.8.1 我们百度搜索一下看…

备受好评的几个视频素材网站,后期剪辑必看~

现在市面上大大小小的视频素材网站一搜一大把&#xff0c;但是真正能够称得上宝藏实用的却寥寥无几&#xff0c;做过后期的下伙伴们都知道素材站的重要性&#xff0c;一些周期短需要赶时间的项目&#xff0c;根本来不及去实拍&#xff0c;这个时候一个好的素材站真的算得上是救…

自动化测试入门 —— 自动化测试概论

整篇论述总的来讲会很长&#xff0c;从自动化的思维、模型、工具&#xff0c;到各层次的自动化测试技术、测试框架、测试平台&#xff0c;包括面向未来的自动化技术都将涉及&#xff0c;因此打算拆成几个部分去写。此外&#xff0c;由于涉及的范围比较广泛&#xff0c;部分内容…

opencv入门到精通——OpenCV中的绘图功能

目录 目标 代码 画线 画矩形 画圆圈 画椭圆 画多边形 向图像添加文本&#xff1a; 结果 目标 学习使用OpenCV绘制不同的几何形状 您将学习以下功能&#xff1a;cv.line()&#xff0c;cv.circle()&#xff0c;cv.rectangle()&#xff0c;cv.ellipse()&#xff0c;cv.pu…

一个很好用的Docker可视化管理工具

目录 前言Portainer安装部署使用 前言 一个好的docker可视化管理工具&#xff0c;可以提升我们不少的工作效率&#xff0c;下面我就推荐一个我使用过的&#xff0c;感觉很不错的一个可视化管理工具给大家 Portainer Portainer是一个开源的Docker管理工具&#xff0c;提供了容…

Bert-vits2-v2.2新版本本地训练推理整合包(原神八重神子英文模型miko)

近日&#xff0c;Bert-vits2-v2.2如约更新&#xff0c;该新版本v2.2主要把Emotion 模型换用CLAP多模态模型&#xff0c;推理支持输入text prompt提示词和audio prompt提示语音来进行引导风格化合成&#xff0c;让推理音色更具情感特色&#xff0c;并且推出了新的预处理webuI&am…