探索数据可视化:Matplotlib 基础指南

图形绘制

import numpy as np
import pandas as pd
import matplotlib.pyplot as pltx = np.linspace(0,2 * np.pi,100)# 说明:正弦波。x:NumPy数组
# 所有的数据,进行正弦计算
y = np.sin(x)plt.plot(x,y)# 指定x轴范围
plt.xlim(-1,10)
# 指定y轴范围
plt.ylim(-1.5,1.5)# color = 'green' 指定网格颜色;
# alpha = 0.5 指定网格线的透明度
# linestyle = '--' 指定网格线的线型
# linewidth = 1 指定网格线的线宽
plt.grid(color = 'green',alpha = 0.5,linestyle = '--',linewidth = 1)

在这里插入图片描述

设置字体、坐标轴刻度、标签、标题

# 查看字体
from matplotlib import font_manager
fm = font_manager.FontManager()
[font.name for font in fm.ttflist][:10] # 列表生成式,只拿前10个字体
"""
['cmb10','cmex10','DejaVu Sans Mono','DejaVu Serif','STIXSizeOneSym','DejaVu Serif','STIXSizeThreeSym','DejaVu Serif','cmtt10','STIXGeneral']
"""# figsize=(9,6) 指定图形窗口的大小;图形窗口宽度为 9 英寸,高度为 6 英寸。
plt.figure(figsize=(9,6))
plt.plot(x,y)# 设置字体
# STKaiti 常用于显示中文文本
plt.rcParams['font.family'] =  'STKaiti'
# 设置字体大小
plt.rcParams['font.size'] = 28
# 设置数字负号
plt.rcParams['axes.unicode_minus'] = False# 设置标题
plt.title('正弦波',fontsize = 18, color = 'red',pad = 20)# 设置x与y轴标签
plt.xlabel('X')
plt.ylabel('f(x) = sin(x)',rotation = 0,horizontalalignment = 'right')# yticks 用于设置 y 轴的刻度位置和标签
#[-1, 0, 1] 指定 y 轴三个刻度位置分别为 -1、0 和 1。
a = plt.yticks([-1,0,1])# 设置x轴刻度
# [0, np.pi/2, np.pi, 1.5*np.pi, 2*np.pi] 指定x 轴上显示的刻度位置
# [0, r'$\frac{\pi}{2}$', r'$\pi$', r'$\frac{3\pi}{2}$', r'$2\pi'] 是与刻度位置对应的标签列表。
# 这里使用了 LaTeX 格式来显示数学符号
_ = plt.xticks([0,np.pi/2,np.pi,1.5*np.pi,2*np.pi],[0,r'$\frac{\pi}{2}$',r'$\pi$',r'$\frac{3\pi}{2}$',r'$2\pi$'],color = 'red')# 字符串前面+r表示转义

在这里插入图片描述

图例

# 1、图形绘制x = np.linspace(0,2*np.pi) # x轴y = np.sin(x) # y轴 正弦# 绘制线形图
plt.figure(figsize=(9,6)) # 调整尺寸
plt.plot(x,y)
plt.plot(x,np.cos(x)) # 余弦波
plt.plot(x,np.sin(x) + np.cos(x))# 2、图例
plt.legend(['Sin','Cos','Sin + Cos'],fontsize = 18,loc = 'center',ncol = 3,bbox_to_anchor = (0,1,1,0.2)) # x,y,widht,height
<matplotlib.legend.Legend at 0x2761cc3e208>

在这里插入图片描述

脊柱移动(坐标轴)

“脊柱”(Spines)是图形的四个边框线,它们分别位于图形的顶部、底部、左侧和右侧。你可以通过调整脊柱的位置来实现脊柱移动

x = np.linspace(-np.pi,np.pi,50)
# 设置数字负号
plt.rcParams['axes.unicode_minus'] = False
# facecolor ='lightblue' 设置图形对象的背景颜色为浅蓝色
plt.figure(figsize=(9,6),facecolor='lightblue')# plot绘制了两个图形,x-y成对出现
plt.plot(x,np.sin(x),x,np.cos(x),color = 'cyan')# 获取当前子视图
ax = plt.gca() # 获取当前视图# 将图形对象 ax 的背景颜色设置为一个随机生成的颜色
ax.set_facecolor(np.random.rand(3))# 右边和上面脊柱消失
# ax.spines['right'].set_color('white') # 右边脊柱设置为白色
ax.spines['right'].set_alpha(0)
ax.spines['top'].set_alpha(0)# 设置下面左边脊柱位置,data表示数据,axes表示相对位置0~1
ax.spines['bottom'].set_position(('data',0)) # 底部脊柱定位在 y 轴的 0 点上(竖直中间)
ax.spines['left'].set_position(('data',0)) # 水平中间# 设置刻度及刻度标签
plt.yticks([-1,0,1],labels=['-1','0','1'],fontsize = 18)
_ = plt.xticks([-np.pi,-np.pi/2,np.pi/2,np.pi],labels=[r'$-\pi$',r'$-\frac{\pi}{2}$',r'$\frac{\pi}{2}$',r'$\pi$'],fontsize = 18)# 显示网格线
plt.grid()# 将图形以 300 DPI 的分辨率保存为一个 PDF 文件,文件名为 2.pdf,保存在当前工作目录中
plt.savefig('./2.pdf',dpi = 300)

在这里插入图片描述

风格样式

颜色、线形、点形、线宽、透明度
x = np.linspace(0,2*np.pi,20) # 等差数列,20个
y1 = np.sin(x)
y2 = np.cos(x)# color = indigo:颜色为靛蓝色,线型,点型
# ls='-.': 设置线条的线型为点划线
# marker='p': 设置数据点的标记为五边形(pentagon)
plt.plot(x, y1, color = 'indigo', ls = '-.', marker = 'p')# rgb颜色表示 256 0 ~ 255 
# 0 、1、2……A、B、C、D、E、F
# marker='o'数据点标记为圆形
plt.plot(x, y2, color = '#FF00EE', ls = '--', marker = 'o')# 0 ~ 1之间
plt.plot(x, y1 + y2, color = (0.2,0.7,0.2), ls = ':', marker = '*')# 线宽设置为5
# 透明度为0.3
plt.plot(x,y1 + 2*y2,linewidth = 5,alpha = 0.3,color = 'orange') # 参数连用:参数含义:b --- blue; o marker圆圈; --虚线
plt.plot(x, 2*y1 - y2, 'bo--') 
[<matplotlib.lines.Line2D at 0x2761c671308>]

在这里插入图片描述

def f(x):return np.exp(-x) * np.cos(2*np.pi*x)x = np.linspace(0,5,50)
plt.figure(figsize=(9,6))# plot 参数
plt.plot(x,f(x),color = 'purple',ls = '--', # 折线样式lw = 2, # 线宽alpha = 0.6, # 折线的透明度marker = 'o', #  数据点为圆形markerfacecolor = 'red',# 点颜色markersize = 10,# 点大小markeredgecolor = 'green',#点边缘颜色markeredgewidth = 3)#点边缘宽度plt.xticks(size = 18) # 设置刻度标签的字体大小为 18 磅
_ = plt.yticks(size = 18)

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/522173.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

EXSI create datastore

文章目录 1. 简介2. 清空磁盘3. 删除表4. 创建database 1. 简介 在 ESXi 环境中创建数据存储(Datastore)的步骤如下: 登录 vSphere Web Client 打开 Web 浏览器,输入 ESXi 主机或 vCenter Server 的 IP 地址,使用有权限的账户登录。 在 ESXi 环境中创建数据存储(Datastore)…

使用 Docker 部署 File Browser 文件管理系统

1&#xff09;File Browser 介绍 官网&#xff1a;https://filebrowser.org/ GitHub&#xff1a;https://github.com/filebrowser/filebrowser 今天为大家分享一款开源的私有云盘项目&#xff1a;File Browser&#xff0c;简单实用、轻量级、跨平台&#xff0c;安装部署简单快…

图文并茂的讲清楚Linux零拷贝技术

今天我们来聊一聊Linux零拷贝技术&#xff0c;今天我们以一个比较有代表性的技术sendfile系统调用为切入点&#xff0c;详细介绍一下零拷贝技术的原理。 1.零拷贝技术简介 Linux零拷贝技术是一种优化数据传输的技术&#xff0c;它可以减少数据在内核态和用户态之间的拷贝次数&…

基于java SSM校园兼职平台系统设计和实现

基于java SSM校园兼职平台系统设计和实现 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方…

RabbitMQ的Windows版安装教程

文章目录 前言一、Windows安装RabbitMQ总结 前言 曾经写过一篇关于RabbitMQ的Ubuntu安装教程&#xff08;http://t.csdnimg.cn/5CYfC&#xff09;&#xff0c;当时使用的是Docker将RabbitMQ安装到虚拟机上&#xff0c;但是有很多小伙伴问Windows上如何进行安装RabbitMQ&#x…

神经网络softmax算法与卷积层

多类分类&#xff1a; 多类是分类算法中的一种&#xff0c;它区别于我们的0&#xff0c;1这样子的二进制分类&#xff0c;它会有多个分类的标签&#xff0c;让我们去取其中的一个。 softmax函数&#xff1a; softmax回归算法是我们的sigmoid回归的推广。 上图就是softmax运…

java项目线上捉BUG经验记录

一 线上问题 昨晚上突然接到公司紧急来电电桩设备大面积离线&#xff0c;意味着某市的车无法充电……”&#xff0c;细想这个平台很久都没有更新&#xff0c;最近出现问题是刚好在一个月前也是出现这种情况&#xff0c;再上一次就是几年前更新的。平台平时是稳定&#xff0c;开…

获取C语言语句对应的汇编码和机器指令

借助IDE的调试功能 以CodeBlocks为例&#xff0c;先设置断点&#xff0c;然后点击红色三角形调试。 然后选择Debug➡ Debugging Windows➡Disassembly 就可以看到了 使用命令行 在工程文件中&#xff0c;一般可以找到一个.o文件。如果没有&#xff0c;可以先在program.c的目录下…

c++提高部分

c++提高部分 这部分主要涉及泛型编程和STL技术 1. 模版 1.1 模版的概念 模版就是通用的模具,大大提高复用性,但需要根据需求改动一些东西 1.2 函数模版 c++另一种编程思想为泛型编程,主要利用的技术就是模版c++提供两种模版机制:函数模板和类模板1.2.1 函数模板语法 …

NFT Insider #122:OpenSea与科切拉音乐节合作推出NFT系列,Flowty联合创始人购入勒布朗・詹姆斯NFT

引言&#xff1a;NFT Insider由NFT收藏组织WHALE Members (https://twitter.com/WHALEMembers)、BeepCrypto (https://twitter.com/beep_crypto) 联合出品&#xff0c;浓缩每周NFT新闻&#xff0c;为大家带来关于NFT最全面、最新鲜、最有价值的讯息。每期周报将从NFT市场数据&a…

【Spring云原生系列】Spring RabbitMQ:异步处理机制的基础--消息队列 原理讲解+使用教程

&#x1f389;&#x1f389;欢迎光临&#xff0c;终于等到你啦&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;持续更新的专栏《Spring 狂野之旅&#xff1a;从入门到入魔》 &a…

代码随想录第52天| ● 392.判断子序列 ● 115.不同的子序列

文章目录 ● 392.判断子序列思路代码&#xff1a; ● 115.不同的子序列思路&#xff1a;代码&#xff1a; ● 392.判断子序列 思路 递推顺序&#xff1a;从上到下 从左到右 代码&#xff1a; class Solution {public boolean isSubsequence(String s, String t) {int[][]dpn…