一次性掌握所有 Python 画图基础操作

一次性掌握所有 Python 画图基础操作pythonpythonpython画图介绍本文以实用为第一目标,保证读者在看完此文之后可以迅速上手pythonpythonpython画图,掌握所有画图的基本技巧。库加载我们使用matplotlib来进行pythonpythonpython画图,具体的库加载以及初始设置代码如下所示。importnumpyasnp #加载数学库用于函数描述importmatp…

大家好,又见面了,我是你们的朋友全栈君。

p y t h o n python python 画图介绍 嘿!彩蛋!感觉有帮助就三连呗!

本文以实用为第一目标,保证读者在看完此文之后可以迅速上手 p y t h o n python python 画图,掌握所有画图的基本技巧。(收藏的同时点个赞呗ヽ(•̀ω•́ )ゝ)

如果你对这篇文章可感兴趣,可以点击「【访客必读 – 指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。

相关文章:

库加载

我们使用 matplotlib 来进行 p y t h o n python python 画图,具体的库加载以及初始设置代码如下所示。

import numpy as np	# 加载数学库用于函数描述
import matplotlib
import matplotlib.pyplot as plt
from matplotlib import style

matplotlib.rcParams['text.usetex'] = True  # 开启Latex风格
plt.figure(figsize=(10, 10), dpi=70)  # 设置图像大小
# style.use('ggplot') # 加载'ggplot'风格
# f, ax = plt.subplots(1, 3) # 设置子图

每一段代码都有注释,可以根据注释把握每行代码的内容。看不懂也没有关系,先把代码加上,继续往下看即可。

p y t h o n python python 画图的原理

其实原理非常简单,就是给出一个横坐标的 l i s t list list,再给出一个对应的纵坐标 l i s t list list,然后设置点大小、点外框大小、线大小、点颜色、线颜色、点形状、线形状、标题、标签即可。设置部分的内容看起来很多,但其实也可以不用设置,不设置就代表使用默认的大小、形状以及颜色。

除此之外,画图最主要的分类就是画点还是将点连线,如果使用 scatter 函数,则将散点画在图中;如果使用 plot 函数,则会将散点连线,在下文中,读者将会更深刻地感受到这一点。

图像加载

# plt.tight_layout() # 当有多个子图时,可以使用该语句保证各子图标题不会重叠
# plt.savefig('myplot1.pdf', dpi=700) # dpi 表示以高分辨率保存一个图片文件,pdf为文件格式,输出位图文件
plt.show() # 渲染图片

上述的代码中主要就是 plt.show() 语句,其余语句都是一些其余设置,看注释即可明白。

画图分类

python 中画图主要分为下述几类。

  • 画单点
  • 画散点
  • 画散点连线
  • 画函数

主要涉及到的一些 操作 分为下述几类。

  • 子图
  • 设置横纵坐标范围
  • 图像标题
  • 图像中画图类型的标签

画单点

画单点比较简单,给出下述代码以及返回结果即可掌握。(需要加入最开头给出的初始设置内容)

def main():
    X = 1
    Y = 100
    plt.scatter(X, Y, s=50)	// s为点大小
    plt.show()

Alt
上图是加载了 style.use('ggplot') 该风格后的效果,如果去掉该行,输出将如下所示。
在这里插入图片描述
读者可以根据自己的喜好选择该风格,也可以去搜索其他的风格,下文接下来的示例将均使用 'ggplot' 风格进行展示。


画散点

知道了画单点的方法之后,画散点就变得非常简单,因为我们只需要将单点中传入的单变量改成一个 l i s t list list 即可,具体代码和效果如下所示。

def main():
    X, Y = [], []
    for i in range(1, 10):
        X.append(i)
        Y.append(np.sin(i))
    plt.scatter(X, Y, s=50)
    plt.show()

在这里插入图片描述


散点连线

只有散点,通常会使得图像变得不够直观,因此我们使用 plot 函数将所有散点连在一起,具体操作如下所示。

def main():
    X, Y = [], []
    for i in range(1, 10):
        X.append(i)
        Y.append(np.sin(i))
    plt.plot(X, Y, s=50)
    plt.show()

在这里插入图片描述

我们也可以对 plot 函数进行设置,即可输出如下所示图形。

def main():
    X, Y = [], []
    for i in range(1, 10):
        X.append(i)
        Y.append(np.sin(i))
    plt.plot(X, Y, '-p', color='grey',
        marker = 'o',
        markersize=8, linewidth=2,
        markerfacecolor='red',
        markeredgecolor='grey',
        markeredgewidth=2)
    plt.show()

在这里插入图片描述
可以看到我们对于点大小、颜色、点外框颜色、大小以及线颜色、线宽均进行了设置,读者可以自行选择设置选项进行尝试。


画函数

尽管散点连线了,但是由于散点的密度不够大,因此我们可以进一步的使用
只有散点,通常会使得图像变得不够直观,因此我们使用 plot 函数将所有散点连在一起,具体操作如下所示。

def main():
    X = np.linspace(1, 10, 100)	# 将[1,10]区间均分为100个点,得到100个横坐标
    Y = np.sin(X) # 求出100个点的纵坐标
    plt.plot(X, Y, color="red", linewidth=1.0, linestyle="-") # 将100个散点连在一起
    plt.show()

在这里插入图片描述

线条形状、颜色、标签

在画函数中我们可以设置线条形状 linestyle 、线条宽度 linewidth 以及线条颜色 color。我们接下来介绍常见的几种线条形状以及如何给线条加上标签,并给出具体的代码供读者参考。

def main():
    X = np.linspace(1, 10, 100)
    Y1 = np.sin(X)
    Y2 = np.cos(X)
    Y3 = -X
    Y4 = X
    plt.plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label="-")
    plt.plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label="--")
    plt.plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label="-.")
    plt.plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=":")
    plt.legend(loc="best") # 把标签加载到图中哪个位置
    plt.show()

常见的 linestyle 还有 '-', '--', '-.', ':', 'solid', 'dashed', 'dashdot', 'dotted',读者可以自行尝试。
常见的 legendloc 位置还有 best, upper right, upper left, lower left, lower right, right, center left, center right, lower center, upper center, center,其中 best 表示将标签加载到 python 认为最佳的位置。
在这里插入图片描述

支持 Latex 的标签

由于是函数作图,因此我们通常会将标签设置为线条所代表的函数值,因此我们需要介绍支持 Latex 的标签。我们将 label 的数值设置为 r'$x_n$' 即可支持 L a t e x Latex Latex,如下图所示。

def main():
    X = np.linspace(0, 1, 100)
    Y1 = np.sqrt(X)
    Y2 = X
    Y3 = X * X
    Y4 = X * X * X
    plt.plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label=r"$y_1=\sqrt{x}$")
    plt.plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label=r"$y_2=x$")
    plt.plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label=r"$y_3=x^2$")
    plt.plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=r"$y_4=x^3$")
    plt.legend(loc="best")
    plt.show()

在这里插入图片描述

设置横纵坐标标号以及图像标题

最后我们需要介绍如何给该图像设置横纵坐标、范围以及标题。我们首先不设置范围,则具体代码以及输出图形如下。

def main():
    X = np.linspace(0, 1, 100)
    Y1 = np.sqrt(X)
    Y2 = X
    Y3 = X * X
    Y4 = X * X * X
    plt.plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label=r"$y_1=\sqrt{x}$")
    plt.plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label=r"$y_2=x$")
    plt.plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label=r"$y_3=x^2$")
    plt.plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=r"$y_4=x^3$")
    plt.legend(loc="best")

    # x、y坐标以及标题
    plt.xlabel('x', fontsize=18)
    plt.ylabel('y', fontsize=18)
    plt.title(r'$f(x)=\sqrt{x},x,x^2,x^3$', fontsize=18)
    plt.show()

在这里插入图片描述

设置横纵坐标的范围

有的时候我们会觉得系统默认的横纵坐标范围不合适,因此我们需要自行设置横纵坐标,具体代码以及结果如下所示。

def main():
    X = np.linspace(0, 2, 100)
    Y1 = np.sqrt(X)
    Y2 = X
    Y3 = X * X
    Y4 = X * X * X
    plt.plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label=r"$y_1=\sqrt{x}$")
    plt.plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label=r"$y_2=x$")
    plt.plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label=r"$y_3=x^2$")
    plt.plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=r"$y_4=x^3$")
    plt.legend(loc="best")

    # x、y坐标以及标题
    plt.xlabel('x', fontsize=18)
    plt.ylabel('y', fontsize=18)
    plt.title(r'$f(x)=\sqrt{x},x,x^2,x^3$', fontsize=18)

    # 设置坐标范围
    plt.ylim(-1, 4)
    plt.xlim(-1, 4)
    plt.show()

在这里插入图片描述

给函数中的一个点标号

当函数比较复杂的时候,我们往往需要对关键点进行标号,通常使用的方式是加箭头或者不加,我们先给出加箭头的代码以及结果。

def main():
    X = np.linspace(0, 1, 100)
    Y1 = np.sqrt(X)
    Y2 = X
    Y3 = X * X
    Y4 = X * X * X
    plt.plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label=r"$y_1=\sqrt{x}$")
    plt.plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label=r"$y_2=x$")
    plt.plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label=r"$y_3=x^2$")
    plt.plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=r"$y_4=x^3$")
    plt.legend(loc="best")

    # x、y坐标以及标题
    plt.xlabel('x', fontsize=18)
    plt.ylabel('y', fontsize=18)
    plt.title(r'$f(x)=\sqrt{x},x,x^2,x^3$', fontsize=18)

	# 关键点标号
    plt.scatter(1, 1, s=100)
    plt.ylim(-1, 2)
    plt.annotate('End Point', fontsize=20,
                 xy=(1, 1), xycoords='data',
                 xytext=(0.8, 0.95), textcoords='axes fraction',
                 arrowprops=dict(facecolor='black', shrink=0.1),
                 horizontalalignment='right', verticalalignment='top')
    plt.show()

其中 xy(1,1) 表示关键点的位置,xycoords='data' 表示关键点坐标所采用的坐标方式, shrink 参数表示箭头距离关键点的距离,horizontalalignment='right', verticalalignment='top' 均表示注释的位置。
在这里插入图片描述
也可以使用不加箭头的方式,即将上述 annotate 换成下述代码即可。

	# 关键点标号
	plt.scatter(1, 1, s=100)
	plt.ylim(-0.1, 1.3)
	plt.xlim(-0.1, 1.3)
	plt.annotate("End Point",
	             xy=(1.05, 1.05),
	             fontsize=20,
	             xycoords="data")

在这里插入图片描述

色卡

当绘制多个函数时,会发现颜色的设计非常难把握,因此下图给出一张色卡供颜色选择。
在这里插入图片描述


子图

最后是如何用 python 画子图,其实画子图就是将上述的 p l t plt plt 换成 a x ax ax,具体操作的思路与之前的操作并没有太大的区别,接下来给出一个包含横纵坐标、函数坐标、标题的完整子图代码,读者可以从代码中获取相应操作的代码。

在这里插入图片描述

import numpy as np
import matplotlib
import matplotlib.pyplot as plt
from matplotlib import style

style.use('ggplot')  # 加载'ggplot'风格
matplotlib.rcParams['text.usetex'] = True  # 开启Latex风格
plt.figure(figsize=(10, 10), dpi=70)  # 设置图像大小
f, ax = plt.subplots(2, 2)  # 设置子图


def func1():
    X = np.linspace(0, 1, 100)
    Y1 = np.sqrt(X)
    # ax[0][0]的设置
    ax[0][0].plot(X, Y1, color="lightcoral", linewidth=3.0, linestyle="-", label=r"$y_1=\sqrt{x}$")
    ax[0][0].set_xlabel('x', fontsize=10)
    ax[0][0].set_ylabel('y', fontsize=10)
    ax[0][0].set_title(r'$f(x)=\sqrt{x}$', fontsize=16)
    ax[0][0].legend(loc="best")

    # ax[0][0]关键点
    ax[0][0].scatter(0.5, np.sqrt(0.5), s=100)
    ax[0][0].annotate("End Point",
                      xy=(0.6, 0.5),
                      fontsize=12,
                      xycoords="data")


def func2():
    X = np.linspace(0, 1, 100)
    Y2 = X
    # ax[0][1]的设置
    ax[0][1].plot(X, Y2, color="burlywood", linewidth=3.0, linestyle="--", label=r"$y_2=x$")
    ax[0][1].set_xlabel('x', fontsize=10)
    ax[0][1].set_ylabel('y', fontsize=10)
    ax[0][1].set_title(r'$f(x)=x$', fontsize=16)
    ax[0][1].legend(loc="best")

    # ax[0][1]关键点
    ax[0][1].scatter(0.5, 0.5, s=100)
    ax[0][1].annotate("End Point",
                      fontsize=12,
                      xytext=(0.7, 0.1),
                      xy=(0.5, 0.5),
                      xycoords="data",
                      arrowprops=dict(facecolor='gray', shrink=0.15))


def func3():
    X = np.linspace(0, 1, 100)
    Y3 = X * X
    # ax[1][0]的设置
    ax[1][0].plot(X, Y3, color="mediumturquoise", linewidth=3.0, linestyle="-.", label=r"$y_3=x^2$")
    ax[1][0].set_xlabel('x', fontsize=10)
    ax[1][0].set_ylabel('y', fontsize=10)
    ax[1][0].set_title(r'$f(x)=x^2$', fontsize=16)
    ax[1][0].legend(loc="best")

    # ax[1][0]关键点
    ax[1][0].scatter(0.5, 0.5 * 0.5, s=100)
    ax[1][0].annotate("End Point",
                      fontsize=12,
                      xytext=(0.05, 0.6),
                      xy=(0.5, 0.5 * 0.5),
                      xycoords="data",
                      arrowprops=dict(facecolor='black', shrink=0.1))


def func4():
    X = np.linspace(0, 1, 100)
    Y4 = X * X * X
    # ax[1][1]的设置
    ax[1][1].plot(X, Y4, color="mediumpurple", linewidth=3.0, linestyle=":", label=r"$y_4=x^3$")
    ax[1][1].set_xlabel('x', fontsize=10)
    ax[1][1].set_ylabel('y', fontsize=10)
    ax[1][1].set_title(r'$f(x)=x^3$', fontsize=16)
    ax[1][1].legend(loc="best")

    # ax[1][1]关键点
    ax[1][1].scatter(0.5, 0.5 * 0.5 * 0.5, s=100)
    ax[1][1].annotate("End Point",
                      xy=(0.2, 0.3),
                      fontsize=12,
                      xycoords="data")


def main():
    func1()
    func2()
    func3()
    func4()

    plt.tight_layout()  # 当有多个子图时,可以使用该语句保证各子图标题不会重叠
    plt.savefig('myplot1.pdf', dpi=700)  # dpi 表示以高分辨率保存一个图片文件,pdf为文件格式,输出位图文件
    plt.show()


if __name__ == "__main__":
    main()

另外,也可以使用 plt.sca() 来定位子图,如下述例子:

f, ax = plt.subplots(2, 3, figsize=(15, 10)) # 声明 2 行 3 列的子图
f.suptitle("设置总标题", fontsize=18)

plt.sca(ax[0, 1]) # 定位到第 1 行第 2 列的子图
# 接下来直接使用 plt 画图即可

后记

上述所涉及的内容即为 p y t h o n python python 应用 matplotlib 画图的基本操作了,如果想要进一步的深化画图能力,推荐根据需求在 matplotlib 官方文档 中进行搜索。祝大家在 python 画图的路上更进一步!???

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/130122.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • VMware虚拟机安装Debian10 (超级详细)

    零基础虚拟机安装debian10

    2022年4月13日
    48
  • 802.1ag CFM/802.3ah EFM OAM/Y.1731 ETH OAM学习笔记

    802.1ag CFM/802.3ah EFM OAM/Y.1731 ETH OAM学习笔记相关协议:1)IEEE802.1ag连通性故障管理(CFM:ConnectivityFaultManagement)2)IEEE802.3ah第一英里的以太网(EFM:EthernetintheFirstMile),其中第57章的以太网OAM3)ITU-TY.1731以太网OAM(Operation,AdministrationandMaintenance

    2025年5月29日
    3
  • MSF搭建socks代理[通俗易懂]

    MSF搭建socks代理[通俗易懂]目录搭建代理添加路由​搭建Socks4a代理搭建Socks5代理连接代理搭建代理当我们通过MSF拿到一个机器的权限后,想通过MSF搭建socks代理,然后通内网。MSF中有三个代理模块,分别是socks4a、socks5、socks_unc。我们一般用socks4a和socks5进行代理。socks5可以设置用户名和密码。这里运行代理后,有时候MSF不会监听端口…

    2022年6月16日
    118
  • 排序 专题讨论

    排序 专题讨论

    2021年10月6日
    36
  • Linux下的双网卡绑定bond0 em1 em2

    一、什么是bonding Linuxbonding驱动提供了一个把多个网络接口设备捆绑为单个的网络接口设置来使用,用于网络负载均衡及网络冗余 二、bonding应用方向1、网络负载均衡 对于bonding的网络负载均衡是我们在文件服务器中常用到的,比如把三块网卡,当做一块来用,解决一个IP地址,流量过大,服务器网络压力过大的问题。对于文件服务器来说,比如NFS或SAMBA文件服

    2022年4月8日
    105
  • 二十三又是谁的二十三

    二十三又是谁的二十三23岁那年你正处在哪个状态?现在呢?我,23岁,应届毕业生。生活,工作,爱情都处于人生的低谷,一穷二白,一无所有,一事无成。分享一下成长的建议吧。匿名用户23岁那年…就是去年…在22岁的时候我毕业,同时第二年准备考研,结果因为压力太大,期望太高,又失利了,但是我依然满怀信心和憧憬在我23岁那年四月,当我深爱的女孩(在这之前我追了她四年)说她要去北京时,我在毫无准备的情况下,带了2000块钱冲到北京,那会的北京还有点冷…但是我只是想打好前站,在她来的时候能提供一点帮助,在前两周里,每天面试两家公

    2022年7月25日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号