Matplotlib是一个Python绘图库,它可以帮助我们创建高质量的2D图表和3D图表。它支持多种类型的图表,包括直方图、散点图、条形图、饼图、箱形图、热力图、树形图和其他复杂的绘图。Matplotlib可以用于创建静态的或动态的可视化,并且可以在多个平台上使用。
Matplotlib例题是一个很好的学习工具,它可以帮助我们快速了解Matplotlib库的使用方法。在这里,我将通过一个例子来说明如何使用Matplotlib库来创建一个散点图。
import matplotlib.pyplot as plt x = [1,2,3,4,5] y = [2,4,6,8,10] plt.scatter(x,y) plt.title('Scatter Plot') plt.xlabel('X-axis') plt.ylabel('Y-axis') plt.show()
上面代码中,我们首先导入matplotlib库中的pyplot模块(即“plt”)。然后定义了x和y轴上的数据列表。最后,使用scatter()函数将x和y轴上的数据连接起来,并使用title()函数将标题添加到散点图中。最后,使用show()函数显示出最后生成的散点图。
matplotlib是基于Python的绘图库,广泛用于Python科学计算界。它完整支持二维绘图以及部分支持三维绘图。该绘图库致力于能适应广泛的用户需求。它可以根据所选的用户接口工具来嵌入绘图算法。与此同时,对于使用GTK+、Qt、Tk、FLTK、wxWidgets与Cocoa的所有主要桌面操作系统,matplotlib能支持交互式绘图。在Python的交互式shell中,我们可以使用简单的、过程式的命令交互式地调用matplotlib来生成图形,与使用Mathematica、IDL或者MATLAB绘图非常相似。matplotlib也可以嵌入到无报文头的Web服务器中,以提供基于光栅(如PNG格式)与向量(如Postscript、PDF以及纸面效果很好的SVG格式)这两种格式的图形硬拷贝。
我们其中一位开发者(John Hunter)与他的研究癫痫症的同事们试图在不借助专有软件的情况下进行脑皮层电图(ECoG)分析,于是便有了最初的matplotlib。John Hunter当时所在的实验室只有一份电图分析软件的许可证,但有各式各样的工作人员,如研究生、医科学生、博士后、实习生、以及研究员,他们轮流共享该专有软件的硬件电子锁。生物医学界广泛使用MATLAB进行数据分析与可视化,所以Hunter着手使用基于MATLAB的matplotlib来代替专有软件,这样很多研究员都可以使用并且对其进行扩展。但是MATLAB天生将数据当作浮点数的数组来处理。然而在实际情况中,癫痫手术患者的医疗记录具有多种数据形式(CT、MRI、ECoG与EEG等),并且存储在不同的服务器上。MATLAB作为数据管理系统勉强能应付这样的复杂性。由于感到MATLAB不适合于这项任务,Hunter开始编写一个新的建立在用户接口工具GTK+(当时是Linux下的主流桌面视窗系统)之上的Python应用程序。
所以matplotlib这一GTK+应用程序最初便被开发成EEG/ECoG可视化工具。这样的用例决定了它最初的软件架构。matplotlib最初的设计也服务于另一个目的:代替命令驱动的交互式图形生成(这一点MATLAB做得很好)工具。MATLAB的设计方法使得加载数据文件与绘图这样的任务非常简单,而要使用完全面向对象的API则会在语法上过于繁琐。所以matplotlib也提供状态化的脚本编程接口来快速、简单地生成与MATLAB类似的图形。因为matplotlib是Python库,所以用户可以使用Python中各种丰富的数据结构,如列表、辞典与集合等等。
A somewhat stripped-down and simplified version of pyplot"s frequently used line plotting function matplotlib.pyplot.plot is shown below to illustrate how a pyplot function wraps functionality in matplotlib"s object-oriented core. All other pyplot scripting interface functions follow the same design.
@autogen_docstring(Axes.plot)
def plot(*args, **kwargs):
ax = gca()
ret = ax.plot(*args, **kwargs)
draw_if_interactive()
return ret
The Python decorator @autogen_docstring(Axes.plot) extracts the documentation string from the corresponding API method and attaches a properly formatted version to the pyplot.plot method; we have a dedicated module matplotlib.docstring to handle this docstring magic. The *args and *kwargs in the documentation signature are special conventions in Python to mean all the arguments and keyword arguments that are passed to the method. This allows us to forward them on to the corresponding API method. The call ax = gca() invokes the stateful machinery to "get current Axes" (each Python interpreter can have only one "current axes"), and will create the Figure and Axes if necessary. The call to ret = ax.plot(args, **kwargs) forwards the function call and its arguments to the appropriate Axes method, and stores the return value to be returned later. Thus the pyplot interface is a fairly thin wrapper around the core Artist API which tries to avoid as much code duplication as possible by exposing the API function, call signature and docstring in the scripting interface with a minimal amount of boilerplate code.
jQuery hasClass() 方法jQuery HTML/CSS 方法实例 检查 p 元素是否包含 intro 类:$(button).click(function(){ alert($(p).hasC...
jQuery offsetParent() 方法jQuery 遍历方法实例 设置 p 元素的最近的被定位的父元素的背景颜色:$(button).click(function(){ $...
jQuery event.isDefaultPrevented() 方法jQuery 事件方法实例 防止链接打开 URL,并检查 preventDefault() 是否被调用:$(a).cli...
jQuery after() 方法jQuery HTML/CSS 方法实例 在每个 p 元素后插入内容:$(button).click(function(){ $(p).after(pHello world...
jQuery children() 方法jQuery 遍历方法实例 返回 ul 的直接子元素:$(document).ready(function(){ $(ul).children().css({colo...