Python-matplotlib库画图小例介绍
off999 2024-09-26 16:06 119 浏览 0 评论
Matplotlib介绍
Matplotlib 是一个 Python 的 2D绘图库,它以各种硬拷贝格式和跨平台的交互式环境生成出版质量级别的图形 。通过 Matplotlib,开发者可以仅需要几行代码,便可以生成绘图,直方图,功率谱,条形图,错误图,散点图等。
Matplotlib库常用函数操作介绍
设置坐标轴
# (1.)spines移动坐标轴
# (2.)xlim方法设置坐标轴刻度取值范围
# (3.)xticks,yticks方法设置x,y轴的刻度标签值
# (4.)title方法设置标题,xlabel,ylabel方法设置坐标轴描述
设置图片上的描述
# (1.)text方法设置图片上的文字描述和注解
# (2.)annotate方法对图片上某个点加注解
# (3.)legend方法设置图像图例
# 可使用如下两种方式:
#1: 在 plt.plot 函数中添加 label 参数后,使用 plt.legend(loc=’up right’)
# 2: 不使用参数 label, 直接使用如下命令:
# 网格线开关plt.grid(True)
# 图像显示plt.show()
# 图像保存savefig(‘../ /.png’)
常用图形
#(1)曲线图:描绘波动,2个维度matplotlib.pyplot.plot(data)
#(2)灰度图:直方图,1个维度matplotlib.pyplot.hist(data)
#(3)散点图:2个维度matplotlib.pyplot.scatter(data)
#(4)箱线图:设定上下限matplotlib.pyplot.boxplot(data)
#(5)饼状图:各类别占比matplotlib.pyplot.pie(data)
Matplotlib库画图小例子-01
import numpy as np
import matplotlib.pyplot as plt
#创建自变量数组
x= np.linspace(-3.14,3.14,10)
#创建函数值数组
y1 = np.sin(x)
plt.figure(1)
#绘制红色曲线
plt.plot(x, y1,'rp-')
#限制y坐标轴范围
plt.ylim(-1.2,1.2)
plt.title("sinx")
plt.xlabel("x")
plt.ylabel("y1")
plt.show()
import numpy as np
import matplotlib.pyplot as plt
#创建自变量数组
x= np.linspace(-3.14,3.14,10)
#创建函数值数组
y2 = np.cos(x)
plt.figure(1)
plt.plot(x,y2,'bp-')
plt.ylim(-1.2,1.2)
plt.title("cosx")
plt.xlabel("x")
plt.ylabel("y2")
plt.show()
import numpy as np
import matplotlib.pyplot as plt
#创建自变量数组
x= np.linspace(-3.14,3.14,10)
#创建函数值数组
y3 =abs(x)/x
plt.figure(1)
plt.plot(x,y3,'gp-')
plt.ylim(-1.2,1.2)
plt.title("|x|/x")
plt.xlabel("x")
plt.ylabel("y3")
plt.show()
可利用subplot在同一张画布上画出图像:
#创建图形
plt.figure(1)
意思是在一个2行2列共4个子图的图中,定位第1个图来进行操作(画图)。
最后面那个1表示第1个子图。那个数字的变化来定位不同的子图
#第一行第一列图形
ax1 = plt.subplot(2,2,1)
plt.title("sinx")
plt.xlabel("x")
plt.ylabel("y1")
#第一行第二列图形
ax2 = plt.subplot(2,2,2)
plt.title("cosx")
plt.xlabel("x")
plt.ylabel("y2")
#第二行
ax3 = plt.subplot(2,1,2)
plt.title("|x|/x")
plt.xlabel("x")
plt.ylabel("y3")
#选择ax1
plt.sca(ax1)
#绘制红色曲线
plt.plot(x, y1,'rp-')
#限制y坐标轴范围
plt.ylim(-1.2,1.2)
#选择ax2
plt.sca(ax2)
#绘制蓝色曲线
plt.plot(x,y2,'bp-')
plt.ylim(-1.2,1.2)
#选择ax3
plt.sca(ax3)
plt.plot(x,y3,'gp-')
plt.ylim(-1.2,1.2)
plt.show()
Matplotlib库画图小例子-02
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.sans-serif']='SimHei'#解决显示中文符号异常问题
plt.rcParams['axes.unicode_minus']=False#显示符号异常问题
x1=np.linspace(0,1,100)
x2=np.arange(-np.pi,np.pi,0.01)
y1=x1**4
y2=x1**2
p1=plt.figure(1)
ax1=plt.subplot(2,1,1)
plt.plot(x1,y2)
plt.plot(x1,y1,'r--')
plt.title('幂函数曲线')
plt.xlabel('x')
plt.ylabel('y')
plt.ylim(0,1)
plt.legend(['y1=x**4','y2=x**2'])
ax2=plt.subplot(2,1,2)
plt.title('sin/cos曲线')
plt.xlabel('rad')
plt.ylabel('value')
plt.xlim(0,np.pi)
plt.ylim(-1.2,1.2)
plt.xticks([-(np.pi),-(np.pi/2),0,np.pi/2,np.pi])
plt.yticks([-1,-0.5,0,0.5,1])
plt.plot(x2,np.sin(x2))
plt.plot(x2,np.cos(x2))
plt.legend(['sin','cos']) #label标签
plt.show()
Matplotlib库画图小例子-03
竖柱形图:
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif']='SimHei'
plt.rcParams['axes.unicode_minus']=False
x=np.arange(6)
num=[1.5,2.5,4.0,3.5,2.6,5.0]
num1=[2,3,4,5,6,4]
width=0.3
label1=['一月','二月','三月','四月','五月','六月']
plt.bar(x,num,width,label='一部门',color='r')
plt.bar(x+width,num1,width,label='二部门',color='b')
plt.xlabel('月份')
plt.ylabel('生产总值(亿元)')
plt.title("2018半年度各月份生产总值直方图")
plt.xticks(x+width/2,label1)
plt.legend()
plt.show()
横柱形图:
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif']='SimHei'
plt.rcParams['axes.unicode_minus']=False
y=np.arange(6)
num=[1.5,2.5,4.0,3.5,2.6,5.0]
num1=[2,3,4,5,6,4]
label1=['一月','二月','三月','四月','五月','六月']
width=0.3
plt.barh(y,num,width,label='一部门',color='y')
plt.barh(y+width,num1,width,label='二部门',color='b')
plt.yticks(range(6),label1)
plt.ylabel('月份')
plt.xlabel('生产总值(亿元)')
plt.title("2018半年度各月份生产总值直方图")
plt.legend()
plt.show()
Matplotlib库画图小例子-04
利用matplotlib画出散点图:
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.sans-serif']='SimHei'
plt.rcParams['axes.unicode_minus']=False
plt.figure(1)
x2=np.random.rand(15)*100
y2=np.random.rand(15)*100
plt.scatter(x2,y2,c='r',s=50,alpha='0.5')
plt.xlabel('x2')
plt.ylabel('y2')
plt.title('随机生成散点图')
plt.show()
Matplotlib库画图小例子-05
matplotlib画出饼形
绘制各季度收益的饼形图:
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.sans-serif']='SimHei'
plt.rcParams['axes.unicode_minus']=False
num=np.random.rand(4)*10
num1=np.random.rand(4)*10
num2=np.random.rand(4)*10
label1=['一月','二月','三月','四月']
label2=['五月','六月','七月','八月']
label3=['九月','十月','十一月','十二月']
plt.pie(num,labels=label1,radius=1.0,autopct='%1.2f%%',pctdistance=0.8)
plt.pie(num1,labels=label2,radius=0.7,autopct="%1.2f%%",pctdistance=0.7)
plt.pie(num,labels=label3,radius=0.4,autopct='%1.2f%%',pctdistance=0.5)
plt.axis('equal')
plt.title('月份收益占比图')
plt.legend()
print("第一季度各月收益为:",num)
print("第二季度各月收益为:",num1)
print("第三季度各月收益为:",num2)
plt.show()
Matplotlib库画图小例子-06
import numpy as np
import matplotlib.pyplot as plt
x=np.linspace(-2,3,20)
y1=3*x+1
y2=x**3
plt.plot(x,y1,'r', label='$y1=3*x+1#39;)
plt.plot(x,y2,'g--',label='$y2=x**3#39;)
plt.xlabel('x')
plt.ylabel('y')
ax=plt.gca()
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')
ax.spines['bottom'].set_position(('data',0))
ax.spines['left'].set_position(('data',0))
ax.set_xlabel('x')
ax.set_ylabel('y')
plt.legend()
plt.show()
——END——
相关推荐
- 阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?
-
TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...
- 高流量大并发Linux TCP性能调优_linux 高并发网络编程
-
其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...
- 性能测试100集(12)性能指标资源使用率
-
在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...
- Linux 服务器常见的性能调优_linux高性能服务端编程
-
一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...
- Nginx性能优化实战:手把手教你提升10倍性能!
-
关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...
- 高并发场景下,Spring Cloud Gateway如何抗住百万QPS?
-
关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...
- Kubernetes 高并发处理实战(可落地案例 + 源码)
-
目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...
- 高并发场景下,Nginx如何扛住千万级请求?
-
Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...
- Spring Boot+Vue全栈开发实战,中文版高清PDF资源
-
SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...
- Docker-基础操作_docker基础实战教程二
-
一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...
- 你有空吗?跟我一起搭个服务器好不好?
-
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...
- 部署你自己的 SaaS_saas如何部署
-
部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...
- Docker Compose_dockercompose安装
-
DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...
- 京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统
-
前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...
- Kubernetes (k8s) 入门学习指南_k8s kubeproxy
-
Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
