利用matplotlib+numpy绘制多种绘图的方法实例

发布时间 - 2026-01-11 00:57:04    点击率:

前言

matplotlib 是Python最著名的绘图库,它提供了一整套和matlab相似的命令API,十分适合交互式地进行制图。本文将以例子的形式分析matplot中支持的,分析中常用的几种图。其中包括填充图、散点图(scatter plots)、. 条形图(bar plots)、等高线图(contour plots)、 点阵图和3D图,下面来一起看看详细的介绍:

一、填充图

参考代码

from matplotlib.pyplot import *
x=linspace(-3,3,100)
y1=np.sin(x)
y2=np.cos(x)
fill_between(x,y1,y2,where=(y1>=y2),color='red',alpha=0.25)
fill_between(x,y1,y2,where=(y<>y2),color='green',alpha=0.25)
plot(x,y1)
plot(x,y2)
show()

简要分析

这里主要是用到了fill_between函数。这个函数很好理解,就是传入x轴的数组和需要填充的两个y轴数组;然后传入填充的范围,用where=来确定填充的区域;最后可以加上填充颜色啦,透明度之类修饰的参数。

当然fill_between函数还有更加高级的用法,详见fill_between用法或者help文档。

效果图

二、散点图(scatter plots)

参考代码

from matplotlib.pyplot import *
n = 1024
X = np.random.normal(0,1,n)
Y = np.random.normal(0,1,n)
T = np.arctan2(Y,X)
scatter(X,Y, s=75, c=T, alpha=.5)
xlim(-1.5,1.5)
ylim(-1.5,1.5)
show()

简要分析

首先介绍一下numpy 的normal函数,很明显,这是生成正态分布的函数。这个函数接受三个参数,分别表示正态分布的平均值,标准差,还有就是生成数组的长度。很好记。

然后是arctan2函数,这个函数接受两个参数,分别表示y数组和x数组,然后返回对应的arctan(y/x)的值,结果是弧度制。

接下来用到了绘制散点图的scatter方法,首先当然是传入x和y数组,接着s参数表示scale,即散点的大小;c参数表示color,我给他传的是根据角度划分的一个数组,对应的就是每一个点的颜色(虽然不知道是怎么对应的,不过好像是一个根据数组内其他元素进行的相对的转换,这里不重要了,反正相同的颜色赋一样的值就好了);最后是alpha参数,表示点的透明度。

至于scatter函数的高级用法可以参见官方文档scatter函数或者help文档。

最后设置下坐标范围就好了。

效果图

三、条形图(bar plots)

参考代码

from matplotlib.pyplot import *
n = 12
X = np.arange(n)
Y1 = (1-X/float(n)) * np.random.uniform(0.5,1.0,n)
Y2 = (1-X/float(n)) * np.random.uniform(0.5,1.0,n)
bar(X, +Y1, facecolor='#9999ff', edgecolor='white')
bar(X, -Y2, facecolor='#ff9999', edgecolor='white')
for x,y in zip(X,Y1):
 text(x+0.4, y+0.05, '%.2f' % y, ha='center', va= 'bottom')
for x,y in zip(X,Y2):
 text(x+0.4, -y-0.05, '%.2f' % y, ha='center', va= 'top')
xlim(-.5,n)
xticks([])
ylim(-1.25,+1.25)
yticks([])
show()

简要分析

注意要手动导入pylab包,否则会找不到bar。。。

首先用numpy的arange函数生成一个[0,1,2,…,n]的数组。(用linspace也可以)

其次用numpy的uniform函数生成一个均匀分布的数组,传入三个参数分别表示下界、上界和数组长度。并用这个数组生成需要显示的数据。

然后就是bar函数的使用了,基本用法也和之前的plot、scatter类似,传入横纵坐标和一些修饰性参数。

接着我们需要用for循环来为柱状图显示数字:用python的zip函数将X和Y1两两配对并循环遍历,得到每一个数据的位置,然后用text函数在该位置上显示一个字符串(注意位置上的细节调整)。text传入横纵坐标,要显示的字符串,ha参数制定横向对齐,va参数制定纵向对齐。

最后调整下坐标范围,并且取消横纵坐标上的刻度以保持美观即可。

至于bar函数的具体用法可以参照bar函数用法或者help文档。

效果图

四、等高线图(contour plots)

参考代码

from matplotlib.pyplot import *
def f(x,y):
 return (1-x/2+x**5+y**3)*np.exp(-x**2-y**2)
n = 256
x = np.linspace(-3,3,n)
y = np.linspace(-3,3,n)
X,Y = np.meshgrid(x,y)
contourf(X, Y, f(X,Y), 8, alpha=.75, cmap=cm.hot)
C = contour(X, Y, f(X,Y), 8, colors='black', linewidth=.5)
clabel(C, inline=1, fontsize=10)
show()

简要分析

首先要明确等高线图是一个三维立体图,所以我们要建立一个二元函数f,值由两个参数控制,(注意,这两个参数都应该是矩阵)。

然后我们需要用numpy的meshgrid函数生成一个三维网格,即,x轴由第一个参数指定,y轴由第二个参数指定。并返回两个增维后的矩阵,今后就用这两个矩阵来生成图像。

接着就用到coutourf函数了,所谓contourf,大概就是contour fill的意思吧,只填充,不描边;这个函数主要是接受三个参数,分别是之前生成的x、y矩阵和函数值;接着是一个整数,大概就是表示等高线的密度了,有默认值;然后就是透明度和配色问题了,cmap的配色方案这里不多研究。

随后就是contour函数了,很明显,这个函数是用来描线的。用法可以类似的推出来,不解释了,需要注意的是他返回一个对象,这个对象一般要保留下来个供后续的加工细化。

最后就是用clabel函数来在等高线图上表示高度了,传入之前的那个contour对象;然后是inline属性,这个表示是否清除数字下面的那条线,为了美观当然是清除了,而且默认的也是1;再就是指定线的宽度了,不解释,。

效果图

五、点阵图

参考代码

from matplotlib.pyplot import *
def f(x,y):
 return (1-x/2+x**5+y**3)*np.exp(-x**2-y**2)
n = 10
x = np.linspace(-3,3,3.5*n)
y = np.linspace(-3,3,3.0*n)
X,Y = np.meshgrid(x,y)
Z = f(X,Y)
imshow(Z,interpolation='nearest', cmap='bone', origin='lower')
colorbar(shrink=.92)
show()

简要分析

这段代码的目的就是将一个矩阵直接转换为一张像照片一样的图,完整的进行显示。

前面的代码就是生成一个矩阵Z,不作解释。

接着用到了imshow函数,传人Z就可以显示出一个二维的图像了,图像的颜色是根据元素的值进行的自适应调整,后面接了一些修饰性的参数,比如配色方案(cmap),零点位置(origin)。

最后用colorbar显示一个色条,可以不传参数,这里传进去shrink参数用来调节他的长度。

效果图

六、3D图

参考代码

import numpy as np
from pylab import *
from mpl_toolkits.mplot3d import Axes3D
fig = figure()
ax = Axes3D(fig)
X = np.arange(-4, 4, 0.25)
Y = np.arange(-4, 4, 0.25)
X, Y = np.meshgrid(X, Y)
R = np.sqrt(X**2 + Y**2)
Z = np.sin(R)
ax.plot_surface(X, Y, Z, rstride=1, cstride=1, cmap=plt.cm.hot)
ax.contourf(X, Y, Z, zdir='z', offset=-2, cmap=plt.cm.hot)
ax.set_zlim(-2,2)
show()

简要分析

有点麻烦,需要用到的时候再说吧,不过原理也很简单,跟等高线图类似,先画图再描线,最后设置高度,都是一回事。

效果图

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用python能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# numpy  # matplotlib  # 绘图  # matplotlib绘图教程  # python使用matplotlib绘制柱状图教程  # python学习之matplotlib绘制散点图实例  # Python+matplotlib绘制不同大小和颜色散点图实例  # python中Matplotlib实现绘制3D图的示例代码  # python使用matplotlib绘制折线图教程  # python使用matplotlib绘制热图  # Python Matplotlib绘制箱线图的全过程  # 是一个  # 等高  # 正态分布  # 文档  # 这两个  # 很明显  # 需要用  # 主要是  # 的是  # 都是  # 这是  # 就好了  # 很好  # 是他  # 第一个  # 给他  # 点阵图  # 是怎么  # 遍历  # 不多 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel任务队列怎么用_Laravel Queues异步处理任务提升应用性能  网站制作企业,网站的banner和导航栏是指什么?  七夕网站制作视频,七夕大促活动怎么报名?  如何快速搭建安全的FTP站点?  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  如何在云虚拟主机上快速搭建个人网站?  如何在宝塔面板中创建新站点?  如何在景安云服务器上绑定域名并配置虚拟主机?  Angular 表单中正确绑定输入值以确保提交与验证正常工作  详解jQuery中的事件  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Laravel中的Facade(门面)到底是什么原理  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  在Oracle关闭情况下如何修改spfile的参数  如何在VPS电脑上快速搭建网站?  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  C++用Dijkstra(迪杰斯特拉)算法求最短路径  网站制作壁纸教程视频,电脑壁纸网站?  Laravel如何实现RSS订阅源功能_Laravel动态生成网站XML格式订阅内容【教程】  Laravel API资源类怎么用_Laravel API Resource数据转换  如何在不使用负向后查找的情况下匹配特定条件前的换行符  网站页面设计需要考虑到这些问题  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  JS实现鼠标移上去显示图片或微信二维码  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  如何将凡科建站内容保存为本地文件?  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  Python面向对象测试方法_mock解析【教程】  Laravel如何配置任务调度?(Cron Job示例)  如何选择可靠的免备案建站服务器?  浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】  如何实现javascript表单验证_正则表达式有哪些实用技巧  EditPlus中的正则表达式 实战(1)  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  如何彻底卸载建站之星软件?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  如何快速启动建站代理加盟业务?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置  Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】  焦点电影公司作品,电影焦点结局是什么?  如何生成腾讯云建站专用兑换码?  Laravel如何生成URL和重定向?(路由助手函数)  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  Laravel如何使用模型观察者?(Observer代码示例)  如何快速搭建高效香港服务器网站?