• 基础介绍

    matplotlib图形对象层级结构:

    图形对象(figure) → 子图对象(axes) → 坐标轴对象(axis) → 定位器对象-刻度线(locator)/格式化器对象-刻度线标签(formatter)

  • 绘图对象创建

    from matplotlib import pyplot as plt
    
    # 创建绘图对象
    fig = plt.figure() # 创建网格子图
    ax1 = fig.add_subplot(rows, cols, idx)
    # 创建手动子图
    ax1 = fig.add_axes([left, bottom, width, height]) # 获取坐标轴对象
    ax1.xaxis
    ax1.yaxis # 设置定位器对象
    ax1.xaxis.set_major_locator(plt.NullLocator)
    ax1.xaxis.set_minor_locator(plt.NullLocator)
    # 设置格式化器对象
    ax1.xaxis.set_major_formatter(plt.NullFormatter)
    ax1.xaxis.set_minor_formatter(plt.NullFormatter)
  • 部分细节控制

    • 颜色支持

      ①. 标准颜色名称, 如: "red"

      ②. 范围在0~1的灰度值, 如: "0.75"

      ③. RGB十六进制, 如: "#FFDD44"

      ④. RGB元组, 范围在0~1, 如: (1.0, 0.2, 0.3)

    • 配色方案支持

      ①. 获取配色方案: plt.cm

      ②. 常见配色方案: "jet", "viridis", "RdBu"

      ③. 离散化配色方案: plt.cm.get_cmap("Blues", 6)

    • 颜色条控制支持

      plt.colorbar(mappable, ticks=range(6), label="digit value", extend="both")

      注意, colorbar本身也是一个子图对象, 创建时依赖于mappable对象

    • linestyle线条风格支持

      ①. "solid"; ②. "dashed"; ③. "dashdot"; ④. "dotted"

    • 散点控制支持

      ①. markersize; ②. markerfacecolor; ③. markeredgecolor; ④. markeredgewidth

      注意, 绘制散点时, plt.plot较plt.scatter性能更好, plt.scatter较plt.plot更加灵活

    • 标签支持

      ①. title; ②. xlabel; ③. ylabel; ④. label; ⑤. legend

    • 图例控制支持

      ax1.legend([labels,] loc="upper left", frameon=False, ncol=2, fontsize=10, title="Area")

    • 文本注释支持

      ax1.text(x, y, text, size, color, ha, va, transform=ax1.transData|ax1.transAxes|fig.transFigure)

    • 坐标轴控制支持

      ax1.set(xlabel, xlim, xticks, xscale)

  • 部分绘图实例

    • 误差绘制

      code
      import numpy
      from matplotlib import pyplot as plt X = numpy.linspace(-1, 1, 30)
      Y = X ** 3 + X ** 2 + X
      YErr = numpy.random.uniform(0.3, 0.7, Y.shape) fig = plt.figure(figsize=(4, 4))
      ax1 = fig.add_subplot(2, 1, 1)
      ax2 = fig.add_subplot(2, 1, 2) ax1.errorbar(X, Y, YErr, fmt="o", color="black", ecolor="lightgray", elinewidth=3, capsize=0)
      ax2.plot(X, Y, "-", color="gray")
      ax2.fill_between(X, Y-YErr, Y+YErr, color="gray", alpha=0.2) fig.savefig("plot.png", dpi=300)
    • 等高线绘制

      code
      import numpy
      from matplotlib import pyplot as plt X = numpy.linspace(-1, 1, 30)
      Y = numpy.linspace(-2, 2, 50)
      X, Y = numpy.meshgrid(X, Y)
      Z = numpy.sin(X) + numpy.cos(Y ** 2) fig = plt.figure(figsize=(10, 3))
      ax1 = fig.add_axes([0.1, 0.1, 0.3, 0.9])
      ax2 = fig.add_axes([0.5, 0.1, 0.3, 0.9]) ax1.contourf(X, Y, Z, 20, cmap="RdGy")
      ax2.imshow(Z, extent=[-1, 1, -2, 2], origin="lower", cmap="RdGy", aspect="auto") fig.savefig("plot.png", dpi=300)
    • 3维曲面绘制

      code
      import numpy
      from matplotlib import pyplot as plt
      from mpl_toolkits import mplot3d X = numpy.linspace(-1, 1, 30)
      Y = numpy.linspace(-2, 2, 50)
      X, Y = numpy.meshgrid(X, Y)
      Z = numpy.sin(X) + numpy.cos(Y ** 2) fig = plt.figure(figsize=(10, 3))
      ax1 = fig.add_subplot(1, 2, 1, projection="3d")
      ax2 = fig.add_subplot(1, 2, 2, projection="3d") ax1.plot_surface(X, Y, Z, rstride=1, cstride=1, cmap="viridis", edgecolor="none")
      ax2.plot_trisurf(X.flatten(), Y.flatten(), Z.flatten(), cmap="viridis", edgecolor="none") fig.tight_layout()
      fig.savefig("plot.png", dpi=300)
    • 直方图与密度图

      code
      import numpy
      import seaborn as sns
      from matplotlib import pyplot as plt X = numpy.random.normal(0, 1, (10000,)) fig = plt.figure(figsize=(10, 3))
      ax1 = fig.add_subplot(1, 2, 1)
      ax2 = fig.add_subplot(1, 2, 2) sns.histplot(X, kde=False, ax=ax1)
      sns.kdeplot(data=X, ax=ax2) fig.savefig("plot.png", dpi=300)
    • 多维矩阵图

      code
      import numpy
      import pandas
      import seaborn as sns X1 = numpy.random.normal(0, 1, (300,))
      X2 = numpy.sin(X1)
      X3 = X1 ** 2
      data = numpy.vstack((X1, X2, X3)).T
      df = pandas.DataFrame(data, columns=["X1", "X2", "X3"]) sns_plot = sns.pairplot(df) sns_plot.savefig("plot.png", dpi=300)
  • 参考文档

    ①. Python Data Science Handbook by Jake VanderPlas (O’Reilly). Copyright 2017 Jake VanderPlas, 978-1-491-91205-8

Python矩阵作图库matplotlib的初级使用(2)的更多相关文章

  1. matplotlib python高级绘图库 一周总结

    matplotlib python高级绘图库 一周总结 官网 http://matplotlib.org/ 是一个python科学作图库,可以快速的生成很多非常专业的图表. 只要你掌握要领,画图将变得 ...

  2. Python 绘图库Matplotlib入门教程

    0 简单介绍 Matplotlib是一个Python语言的2D绘图库,它支持各种平台,并且功能强大,能够轻易绘制出各种专业的图像. 1 安装 pip install matplotlib 2 入门代码 ...

  3. 推荐:python科学计算pandas/python画图库matplotlib【转】

    机器学习基础3--python科学计算pandas(上) 地址:https://wangyeming.github.io/2018/09/04/marchine-learning-base-panda ...

  4. Python数据可视化——使用Matplotlib创建散点图

    Python数据可视化——使用Matplotlib创建散点图 2017-12-27 作者:淡水化合物 Matplotlib简述: Matplotlib是一个用于创建出高质量图表的桌面绘图包(主要是2D ...

  5. python实战学习之matplotlib绘图

    matplotlib 是最流行的Python底层绘图库,主要做数据可视化图表 可以将数据可视化,能够更直观的呈现数据 matplotlib绘图基本要点 首先实现一个简单的绘图 # 导入pyplot f ...

  6. 【python笔记】使用matplotlib,pylab进行python绘图

    一提到python绘图,matplotlib是不得不提的python最著名的绘图库,它里面包含了类似matlab的一整套绘图的API.因此,作为想要学习python绘图的童鞋们就得在自己的python ...

  7. python数据分析scipy和matplotlib(三)

    Scipy 在numpy基础上增加了众多的数学.科学及工程常用的库函数: 线性代数.常微分方程求解.信号处理.图像处理.稀疏矩阵等: Matplotlib 用于创建出版质量图表的绘图工具库: 目的是为 ...

  8. Python中Numpy及Matplotlib使用

    Python中Numpy及Matplotlib使用 1. Jupyter Notebooks 作为小白,我现在使用的python编辑器是Jupyter Notebook,非常的好用,推荐!!! 你可以 ...

  9. 在python中使用图形库matplotlib

    matplotlib is a python 2D plotting library which produces publication quality figures in a variety o ...

  10. [置顶] 如何在Windows 7 64位安装Python,并使用Matplotlib绘图

    1.     安装Python 我使用的是Windows 7 64 bit,所以我从Python官网下载python-2.7.5.amd64.msi,安装步骤如下: 1)        安装windo ...

随机推荐

  1. 无法从“System.ReadOnlyMemory<byte>”转换为“byte[]”

    1.问题复现 RabbitMQ的官方示例:RabbitMQ消费端(接收端)获取消息时抛出异常,具体代码如下 var consumer = new EventingBasicConsumer(chann ...

  2. 基于ChatGPT的API的C#接入研究

    今年开年,最火的莫过于ChatGPT的相关讨论,这个提供了非常强大的AI处理,并且整个平台也提供了很多对应的API进行接入的处理,使得我们可以在各种程序上无缝接入AI的后端处理,从而实现智能AI的各种 ...

  3. 上篇 | 使用 🤗 Transformers 进行概率时间序列预测

    介绍 时间序列预测是一个重要的科学和商业问题,因此最近通过使用基于深度学习 而不是经典方法的模型也涌现出诸多创新.ARIMA 等经典方法与新颖的深度学习方法之间的一个重要区别如下. 概率预测 通常,经 ...

  4. LG P4148 简单题

    \(\text{Code}\) #include <cstdio> #include <iostream> #include <algorithm> #define ...

  5. Ubuntu18.04修改IP地址的方法

    转载csdn: ubuntu18.04更改本地IP_lvjianjin128的博客-CSDN博客 Ubuntu18.04修改IP地址的方法_VLadimir_的博客-CSDN博客_ubuntu18.0 ...

  6. CCRD_TOC_2008年第3期

    中信国健临床通讯 2008年第3期 目 录   银屑病和银屑病关节炎 1.        国际皮肤病专家呼吁重视生物制剂治疗银屑病 原文: http://pharmatimes.com/forums/ ...

  7. WPF Xaml标签的一些特殊符号 如何输入

    小于号 <   输入 <  注意有分号 大于号 >   输入  > 符号 &   输入 & 引号 "  输入 "

  8. sqlserver生成指定的序列

    WITH numbers AS ( SELECT 1 AS num UNION ALL SELECT num + 1 FROM numbers WHERE num < 30 ) SELECT C ...

  9. Nginx 同一个域名自动识别 pc h5

    首先设置环境变量 我们先设置变量,通过判断来改变变量的值(注: 我写在server中) set $is_mobile false; # 初始值 if ( $http_cookie ~* "A ...

  10. Solidity8.0-02

    对应崔棉大师 26-40课程https://www.bilibili.com/video/BV1yS4y1N7yu/?spm_id_from=333.788&vd_source=c81b130 ...