Matplotlib入门[01]——Pyplot

news2025/1/11 18:32:09

Matplotlib入门[01]——Pyplot

参考:

  • https://ailearning.apachecn.org/
  • Matplotlib官网

使用Jupyter进行练习

在这里插入图片描述

Matplotlib简介

matplotlib 是一个 Python2D 图形包。

在线文档:http://matplotlib.org ,提供了 Examples, FAQ, API, Gallery,其中 Gallery 是很有用的一个部分,因为它提供了各种画图方式的可视化,方便用户根据需求进行选择。

import numpy as np
import matplotlib.pyplot as plt

下文中,以 plt 作为 matplotlib.pyplot 的省略。

plt.plot() 函数

举例

# plot函数可以用来绘图
plt.plot([1,2,3,4])
plt.ylabel('some numbers')

plt.show()

在这里插入图片描述

基本用法

plot 函数基本的用法有以下四种:

默认参数

  • plt.plot(x,y)

指定参数

  • plt.plot(x,y, format_str)

默认参数,x0~N-1

  • plt.plot(y)

指定参数,x0~N-1

  • plt.plot(y, format_str)

因此,在上面的例子中,我们没有给定 x 的值,所以其默认值为 [0,1,2,3]

传入 xy

plt.plot([1,2,3,4], [1,4,9,16])
plt.show()

在这里插入图片描述

字符参数

可以用字符来指定绘图的格式:

表示颜色的字符参数有:

字符颜色
‘b’蓝色,blue
‘g’绿色,green
‘r’红色,red
‘c’青色,cyan
‘m’品红,magenta
‘y’黄色,yellow
‘k’黑色,black
‘w’白色,white

表示类型的字符参数有:

字符类型字符类型
'-'实线'--'虚线
'-.'虚点线':'点线
'.'','像素点
'o'圆点'v'下三角点
'^'上三角点'<'左三角点
'>'右三角点'1'下三叉点
'2'上三叉点'3'左三叉点
'4'右三叉点's'正方点
'p'五角点'*'星形点
'h'六边形点1'H'六边形点2
'+'加号点'x'乘号点
'D'实心菱形点'd'瘦菱形点
'_'横线点

例如画出红色圆点蓝色虚线:

plt.plot([1,2,3,4], [1,4,9,16], 'b--',
         [1,2,3,4], [1,4,9,16], 'ro')
plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-79vFirSP-1670229848054)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_13_0.png)]

显示范围

与 MATLAB 类似,这里可以使用 axis 函数指定坐标轴显示的范围:

plt.axis([xmin, xmax, ymin, ymax])
plt.plot([1,2,3,4], [1,4,9,16], 'ro')
# 指定 x 轴显示区域为 0-6,y 轴为 0-20
plt.axis([0,6,0,20])
plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-69Hv33D7-1670229848055)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_16_0.png)]

传入Numpy数组

之前传给 plot 的参数都是列表,事实上,向 plot 中传入 numpy 数组是更常用的做法。事实上,如果传入的是列表,matplotlib 会在内部将它转化成数组再进行处理:

t = np.arange(0., 5., 0.2)

# 不需要使用多个 plot 函数来画多组数组
# 只需要可以将这些组合放到一个 plot 函数中去即可。
plt.plot(t, t, 'r--', 
         t, t**2, 'bs', 
         t, t**3, 'g^')

plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vXL89bPP-1670229848056)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_19_0.png)]
​

线条属性

还可以通过关键词来改变线条的性质,例如 linwidth 可以改变线条的宽度,color 可以改变线条的颜色:

x = np.linspace(-np.pi,np.pi)
y = np.sin(x)

plt.plot(x, y, linewidth=2.0, color='r')

plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QWpK5cli-1670229848057)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_27_0.png)]

使用plt.plot() 的返回值来设置线条属性

plot 函数返回一个 Line2D 对象组成的列表,每个对象代表输入的一对组合,例如:

  • line1, line2 为两个 Line2D 对象

    line1, line2 = plt.plot(x1, y1, x2, y2)

  • 返回 3 个 Line2D 对象组成的列表

    lines = plt.plot(x1, y1, x2, y2, x3, y3)

可以使用这个返回值来对线条属性进行设置:

# 加逗号 line 中得到的是 line2D 对象,不加逗号得到的是只有一个 line2D 对象的列表
line, = plt.plot(x, y, 'r-')

# 将抗锯齿关闭
line.set_antialiased(False)

plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HX8yghun-1670229848057)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_24_0.png)]

plt.setp() 修改线条性质

更方便的做法是使用 pltsetp 函数:

lines = plt.plot(x, y)

# 使用键值对
plt.setp(lines, color='r', linewidth=2.0)

plt.show()

​[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QWpK5cli-1670229848057)(https://note-image-1307786938.cos.ap-beijing.myqcloud.com/typora/01Pyplot%E6%95%99%E7%A8%8B_27_0.png)]

可以设置的属性有很多,可以使用 plt.setp(lines) 查看 lines 可以设置的属性,各属性的含义可参考 matplotlib 的文档。

plt.setp(lines)
  agg_filter: a filter function, which takes a (m, n, 3) float array and a dpi value, and returns a (m, n, 3) array
  alpha: scalar or None
  animated: bool
  antialiased or aa: bool
  clip_box: `.Bbox`
  clip_on: bool
  clip_path: Patch or (Path, Transform) or None
  color or c: color
  contains: unknown
  dash_capstyle: `.CapStyle` or {'butt', 'projecting', 'round'}
  dash_joinstyle: `.JoinStyle` or {'miter', 'round', 'bevel'}
  dashes: sequence of floats (on/off ink in points) or (None, None)
  data: (2, N) array or two 1D arrays
  drawstyle or ds: {'default', 'steps', 'steps-pre', 'steps-mid', 'steps-post'}, default: 'default'
  figure: `.Figure`
  fillstyle: {'full', 'left', 'right', 'bottom', 'top', 'none'}
  gid: str
  in_layout: bool
  label: object
  linestyle or ls: {'-', '--', '-.', ':', '', (offset, on-off-seq), ...}
  linewidth or lw: float
  marker: marker style string, `~.path.Path` or `~.markers.MarkerStyle`
  markeredgecolor or mec: color
  markeredgewidth or mew: float
  markerfacecolor or mfc: color
  markerfacecoloralt or mfcalt: color
  markersize or ms: float
  markevery: None or int or (int, int) or slice or list[int] or float or (float, float) or list[bool]
  path_effects: `.AbstractPathEffect`
  picker: float or callable[[Artist, Event], tuple[bool, dict]]
  pickradius: float
  rasterized: bool
  sketch_params: (scale: float, length: float, randomness: float)
  snap: bool or None
  solid_capstyle: `.CapStyle` or {'butt', 'projecting', 'round'}
  solid_joinstyle: `.JoinStyle` or {'miter', 'round', 'bevel'}
  transform: `matplotlib.transforms.Transform`
  url: str
  visible: bool
  xdata: 1D array
  ydata: 1D array
  zorder: float

子图

figure() 函数会产生一个指定编号为 num 的图:

plt.figure(num) 

使用 subplot 可以在一副图中生成多个子图,其参数为:

plt.subplot(numrows, numcols, fignum) 

numrows * numcols < 10 时,中间的逗号可以省略,因此 plt.subplot(211) 就相当于 plt.subplot(2,1,1)

def f(t):
    return np.exp(-t) * np.cos(2*np.pi*t)

t1 = np.arange(0.0, 5.0, 0.1)
t2 = np.arange(0.0, 5.0, 0.02)

plt.figure(1)
# 两行一列第一个
plt.subplot(211)
plt.plot(t1, f(t1), 'bo', t2, f(t2), 'k')

# 两行一列第二个
plt.subplot(212)
plt.plot(t2, np.cos(2*np.pi*t2), 'r--')
plt.show()

在这里插入图片描述

图形上加上文字

plt.hist() 可以用来画直方图。

mu, sigma = 100, 15
x = mu + sigma * np.random.randn(10000)

# the histogram of the data
n, bins, patches = plt.hist(x, 50, density=True, facecolor='g', alpha=0.75)

plt.xlabel('Smarts')
plt.ylabel('Probability')
plt.title('Histogram of IQ')
plt.text(60, .025, r'$\mu=100,\ \sigma=15$')
plt.axis([40, 160, 0, 0.03])
plt.grid(True)
plt.show()

在这里插入图片描述

对于这幅图形,我们使用 xlabelylabeltitletext 方法设置了文字,其中:

  • xlabel :x 轴标注
  • ylabel :y 轴标注
  • title :图形标题
  • text :在指定位置放入文字

输入特殊符号支持使用 Tex 语法,用 $<some Tex code>$ 隔开。

除了使用 text 在指定位置标上文字之外,还可以使用 annotate 函数进行注释,annotate 主要有两个参数:

  • xy :注释位置
  • xytext :注释文字位置
ax = plt.subplot(111)

t = np.arange(0.0, 5.0, 0.01)
s = np.cos(2*np.pi*t)
line, = plt.plot(t, s, lw=2)

plt.annotate('local max', xy=(2, 1), xytext=(3, 1.5),
            arrowprops=dict(facecolor='black', shrink=0.05),
            )

plt.ylim(-2,2)
plt.show()

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【架构设计】互联网架构项目架构演进以及三高设计概述

系统架构并非一蹴而就&#xff0c;架构目标也是随着业务发展而变化&#xff0c;业务推送技术发展&#xff0c;技术反哺业务。系统架构演进&#xff1a;单机 -->集群 -->分布式微服务 架构演进&#xff08;日活用户占总用户量大概%4到%10&#xff0c;推测总用户量&#x…

Python配置OpenCV

一、背景 有个任务需要进行图像样本扩充&#xff0c;本人想要使用cv2来帮忙扩充电脑重装过系统&#xff0c;之前的环境都没有了参考之前自己写的博客&#xff0c;使用Anaconda安装失败了&#xff0c;一直显示下面的错误&#xff0c;目前还没有解决这个问题 Script file H:\An…

手把手教你音乐服务器搭建

最近发现,经常用的网易云音乐,有很多歌曲下架了,能听的越来越少了;歌单里的一些歌曲,现在要开通 VIP 才能听了。其实自己常听的歌曲不是很多,现在却有很多听不了了。 怎么办呢,付费吗?花钱当然是一个好方式,花 1 分钟开通 VIP,立马就可以畅听起来。 不过前两天翻东西…

RabbitMQ-全面详解(学习总结---从入门到深化)

RabbitMQ概念_MQ 消息队列 MQ全称Message Queue&#xff08;消息队列&#xff09;&#xff0c;是在消息的传输过程中保 存消息的容器。多用于系统之间的异步通信。 1、同步通信相当于两个人当面对话&#xff0c;你一言我一语。必须及时回复 2、异步通信相当于通过第三方转述对话…

看完这套 Java 笔记,才明白笔者同时斩获 7 份大厂 offer 是有原因的

不知道各位程序员朋友有没有做笔记的习惯&#xff1f;不过&#xff0c;我觉得大家还是蛮喜欢收藏笔记的&#xff0c;嘿嘿&#xff0c;我也是。 前几天恰好看到一篇文章&#xff0c;里面详细罗列了关于 Java 的所有知识点。看目录&#xff0c;是从 Jvm 开始&#xff0c;再讲集合…

百趣土壤非靶标代谢组学文献分享,来自Microbiome的灵感

​今天小编要和大家分享的是BIOTREE协助客户发表在Microbiome上的关于土壤抗性遗传的一篇文章。 发表期刊&#xff1a;《Microbiome》 影响因子&#xff1a;9.133 合作单位&#xff1a;南京农业大学 据百趣代谢组学小趣了解&#xff0c;植物方面的高分文章并不好发&#xff…

二分查找详解

&#x1f308;&#x1f308;&#x1f604;&#x1f604; 欢迎小伙伴来到茶色岛独家岛屿&#xff0c;本期会对二分查找进行详细的讲解&#xff0c;做好准备了么&#xff0c;那么开始吧。 &#x1f332;&#x1f332;&#x1f434;&#x1f434; 一、简介 二、查找思路&#xff…

更快更稳更安全!天翼云CDN了解一下

近年来&#xff0c;数字化转型正催生各行各业掀起新一轮的信息变革。作为我国经济发展的“血液”&#xff0c;金融行业的一举一动都牵动着国民经济的神经。相对于其他行业&#xff0c;金融业务因其“高敏感性、高价值”等特点&#xff0c;行业数字化转型需要在保障安全和隐私等…

【基础算法】圆周率的多种方法求算 C++实现

●割圆法 一个圆如下面左图所示&#xff0c;其半径为1&#xff0c;其内部内接一个正六边形。设正六边形的边长为y1。由几何知识可得知y11&#xff0c;所以圆的周长可近似为正六边形的周长C6y16.所以圆周率为前面的近似圆周长与圆直径之比&#xff0c;即C/2 3≈π&#xff0c;这…

关于腾讯股票api股票接口的功能分析

因为国内外股价的上涨都可以在界面上去查询&#xff0c;所以公司能准确地判断股价上涨&#xff0c;并适时买入、卖出&#xff0c;以此获得一定的利润。 腾讯股票api股票接口还可以把以往的数据表示成一条折线&#xff0c;让公司在进行分析时更形象、更有参考意义。在连接界面后…

【数据结构与算法】线性表的查找

&#x1f525; 本文由 程序喵正在路上 原创&#xff0c;CSDN首发&#xff01; &#x1f496; 系列专栏&#xff1a;数据结构与算法 &#x1f320; 首发时间&#xff1a;2022年12月5日 &#x1f98b; 欢迎关注&#x1f5b1;点赞&#x1f44d;收藏&#x1f31f;留言&#x1f43e;…

Java入门教程(5)——开发第一个Java程序

文章目录1.1. 新建一个记事本&#xff0c;将后缀名改为java 如图示&#xff1a; 2.双击&#xff0c;选择打开方式为记事本 输入代码&#xff1a; public class HelloWorld{public static void main(String[] args){System.out.println("Hello world&#xff01;");…

基于DIPUM工具箱对图书数字图像进行处理(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 数字图像处理(Digital Image Processing)将图像信号转换成数字信号并利用计算机对其进行处理,起源于20世纪20年代,目前已广泛地…

电脑硬盘就一个c盘怎么分区,新电脑买回来只有一个c盘怎么分区

电脑硬盘就一个c盘怎么分区&#xff1f;为了方便存储数据&#xff0c;需要对磁盘分区那么&#xff0c;在本文中&#xff0c;易我小编将讲解电脑磁盘分区的实操方法。 一、Diskpart对C盘分区 在Windows操作系统中&#xff0c;Diskpart是命令提示符&#xff0c;可以实现创建分区…

安全面试之基础总结篇【超详细!】

前言 作者简介&#xff1a;不知名白帽&#xff0c;网络安全学习者。 博客主页&#xff1a;不知名白帽的博客_CSDN博客-网络安全,CTF,内网渗透领域博主 安全面试专栏&#xff1a;https://blog.csdn.net/m0_63127854/category_11869916.html 网络安全交流社区&#xff1a;https:…

华为网络模拟器ENSP安装(附安装包)

一、安装前注意事项 1、安装路径 以下所有软件,安装时不建议修改默认路径,尤其ENSP绝对不能安装在电脑主机的中文路径下,否则没法启动。 2、先安装依赖软件 VirtualBox不能安装目录不能有中文,只能装5.0至5.2版本。 WireShark为驱动级软件,需要重启生效,可以在三个软…

WebDAV之葫芦儿·派盘+恒星播放器

恒星播放器 支持WebDAV方式连接葫芦儿派盘。 想要拥有一款万能视频播放器,全能解码播放器,无需转码,支持所有格式的视频和音频,直接播放的播放器?那就选恒星播放器。 恒星播放器支持视屏投屏,倍速播放,后台播放等功能,还能一键截图和录制gif动图。支持全格式超高清真…

企业架构MySQL数据库架构读写分离

学习目标与内容 运维解决方案 读写分离常见的实现方式 MySQL读写分离案列实现 主从复制master配置 主从复制slave配置 简单业务代码实现 用以下代码通过停启主从服务器来检查主从复制原理~ <?php //创建类 class Mysql {//构造方法//当类被实例化时,会触发此方法public fu…

[附源码]Python计算机毕业设计Django居家养老服务系统小程序

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…