当前位置: 首页 > 知识库问答 >
问题:

何时使用matplotlib。pyplot类以及何时使用plot对象(matplotlib.collections.PathCollection)

牧熙云
2023-03-14

我想知道什么时候使用plot实例(这是一个PathCollection)以及什么时候使用plot类本身背后的逻辑是什么。

import matplotlib.pyplot as plt
p = plt.scatter([1,2,3],[1,2,3])

显示散点图。为了让它发挥作用,我必须说:

plt.annotate(...)

并配置轴标签或限制,你写:

plt.xlim(...)
plt.xlabel(...)

等等

但另一方面,你写道:

p.axes.set_aspect(...)
p.axes.yaxis.set_major_locator(...)

这背后的逻辑是什么?我能找个地方查一下吗?不幸的是,我在文档中没有找到这个问题的答案。

何时使用实际实例p配置图形,何时使用pyplot类plt

共有2个答案

鲁德佑
2023-03-14

“plt”只是一个快捷方式,在只有一个绘图时非常有用。当您直接使用plt时,matplotlib会自动创建一个“地物”和一个子地块,但如果您想使用多个子地块,则需要使用“轴”方法,例如:

fig = plt.figure()
a = fig.add_subplot(211)
b = fig.add_subplot(212)
print a.__class__ #<class 'matplotlib.axes.AxesSubplot'>
print fig.__class__ #<class 'matplotlib.figure.Figure'>
a.plot([0,1],[0,1],'r')
b.plot([1,0],[0,1],'b')
fig.show()

这无法直接使用“plt”完成。

宋康安
2023-03-14

根据PEP20:

  • “显性比隐性好。”

通常情况下,“让它正常工作”代码会走py图路线,因为它隐藏了许多人不关心的所有图形和坐标轴管理。这通常用于交互式模式编码、简单的一次性脚本或在高级脚本中执行的绘图。

但是,如果您正在创建一个要进行打印的库模块,并且不能保证库用户没有自己进行任何其他打印,那么最好是显式的,避免使用pyplot接口。我通常将函数设计为接受用户希望操作的轴和/或图形对象作为可选参数(如果未给出,则使用plt.gcf()和/或plt)。gca()。

我的经验法则是,如果我正在执行的操作可以通过pyplot完成,但如果这样做可能会改变“状态机”,那么我会避免pyplot。请注意,通过pyplot执行的任何操作(如plt.xlim())都会获取/设置当前轴/图形/图像(“状态机”),而像ax这样的操作。设置_xlim()不允许。

 类似资料:
  • 我和我的团队一直在使用Spring boot开发一系列微服务。由于服务经历了JUnit和Spring Boot升级(我们现在使用的是Spring Boot 2和JUnit 5),不同开发人员实现的不同JUnit现在使用不同的模式: @扩展为 今天,它们之间的区别是什么?我们真的需要它们来进行单元测试还是嵌入到一些新的Spring Boot注释中?

  • 我正在用Spring web-flux和Reactor一起使用,对我来说,不清楚RestController方法何时返回

  • 问题内容: 在大多数情况下,我将使用异常来检查代码中的条件,我想知道何时才是使用断言的适当时间? 例如, 您能指出断言如何适合这里吗?我应该使用断言吗? 似乎我从未在生产代码中使用断言,而仅在单元测试中看到断言。我确实知道,在大多数情况下,我可以像上面一样使用异常来进行检查,但是我想知道“专业”地执行异常的适当方法。 问题答案: 断言应用于检查不应发生的事情,而异常应用于检查可能发生的事情。 例如

  • 我试图理解Docker Compose和Docker Swarm之间的区别或相似之处。 通过阅读留档,我明白docker-compose提供了一种将不同容器绑定在一起并协同工作的机制,作为一个单一的服务(我猜它使用的功能与用于链接两个容器的--link命令相同) 此外,我对docker-swarm的理解是,它允许您管理不同docker主机的集群,每个主机都运行一些docker-image的几个容器

  • 问题内容: 在哪种情况下,您应该使用原始类型()还是引用类型()? 问题答案: 在哪种情况下,您应该使用原始类型()还是引用类型()? 根据经验,除非必须使用包装原始语言的类,否则我将使用原始语言(例如)。 一种情况是必须使用包装器类,例如在使用泛型的情况下,因为Java不支持将原始类型用作类型参数: 而且,在许多情况下,我将利用autoboxing和unboxing的优势,因此不必显式执行从原语

  • 我有一个Employee类,它有如下3个字段。 为此,我希望根据员工姓名(empName)排序,如果多个员工的姓名相同,则根据员工id(empId)排序。 为此,我编写了一个自定义比较器,使用java.util.比较器如下所示。 我已经创建了8个Employee对象并添加到ArrayList中,如下所示。 并使用上述比较器对列表进行如下排序。 它工作得非常好。但这可以使用类似的方法来完成,如下所示