【python数据分析】绘制双Y轴坐标系

简介: 前言Matplotlib绘制出的图形中会存在一些问题,例如:如何绘制双Y轴坐标系?如何去掉图形默认的边框?以及如何移动坐标到指定位置?下面我们就来看看如何解决

前言

Matplotlib绘制出的图形中会存在一些问题,例如:如何绘制双Y轴坐标系?如何去掉图形默认的边框?以及如何移动坐标到指定位置?下面我们就来看看如何解决


1️⃣twinx()函数

双y轴绘制的关键函数:twinx()。


twinx()函数表示共享x轴,共享表示的就是x轴使用同一刻度线。

使用这个Axes坐标轴实例去调用twinx()函数,从而实现两个Y轴共享一个X轴的效果。


使用add_subplot添加了Axes坐标轴实例。


%matplotlib inline
import pandas as pd
from matplotlib import pyplot as plt
x = range(1,8) 
y = [17, 13, 18, 15, 16, 11, 10]
plt.rcParams['font.sans-serif'] = ['SimHei']     #windows下使用这种方法
fig = plt.figure(figsize=(20,8),dpi=80)
ax = fig.add_subplot(111)
lin1 = ax.plot(x,y,label='开盘价',color='red')
ax.legend(loc=0)
ax.set_ylabel("开盘价(元)")
ax.set_xlabel("日期")
plt.show()


因为,我们会使用这个Axes坐标轴实例去调用twinx()函数,从而实现两个Y轴共享一个X轴的效果。


ax2 = ax.twinx()

ax.twinx()是在ax的坐标轴内创建一个共享X轴的的坐标轴实例。


%matplotlib inline
import pandas as pd
from matplotlib import pyplot as plt
x = range(1,8) 
y = [17, 13, 18, 15, 16, 11, 10]
z=[11,19,7,2,12,86,16]
plt.rcParams['font.sans-serif'] = ['SimHei']     #windows下使用这种方法
fig = plt.figure(figsize=(20,8),dpi=80)
ax = fig.add_subplot(111)
lin1 = ax.plot(x,y,label='开盘价',color='red')
ax.legend()
ax.set_ylabel("开盘价(元)")
ax.set_xlabel("日期")
ax2=ax.twinx()
lin2=ax.plot(x,z,label='收盘价',color='blue')
ax2.legend()
ax2.set_ylabel('收盘价',)
#合并图列
lns = lin1+lin2
labs = [l.get_label() for l in lns]
ax2.legend(lns,labs)
plt.show()


✨效果


合并图例的方法就是仅使用一个轴的legend()函数。


lin1和lin2分别是两个绘图方法plot()的返回值,即折线对象。需要注意的是,lin1和lin2的类型是list。


legend()方法可以指定图例中有哪些值,

第一个参数lns表示将图中的多个线以列表的形势传进去,

第二个参数labs表示将图例的名字以列表的形势传进去。


2️⃣去边框



上图中,一个是Matplotlib默认绘制出的图像,另一个是修改了Matplotlib的一些默认显示方式。


Matplotlib在绘制图形的时候会默认显示上面和右侧的边框,以及坐标轴的颜色默认是黑色。


如果想要去掉默认的边框,通过plt.gca()获得当前的Axes对象


ax = plt.gca()

使用spines属性获取到对应的边框。


ax.spines['right']

right右边框、left左边框、top上边框、bottom下边框。


通过set_color(‘none’)方法可以设置边框的颜色。


ax.spines['right'].set_color('none')

对于颜色的设置,none表示无色,也可以用red、blue等样式的英语单词或者是十六进制的颜色值#0000FF。


import matplotlib.pyplot as plt
y = range(0,14,2) 
x = [-3,-2,-1,0,1,2,3]
# 获得当前图表的图像
ax = plt.gca()
# 设置图型的包围线
ax.spines['right'].set_color('none')
#ax.spines['top'].set_color('none')
#ax.spines['bottom'].set_color('red')
#ax.spines['left'].set_color('#0000FF')
plt.plot(x,y)
plt.show()

我们已经成功的设置边框的颜色,但是还有一个问题就是坐标轴的交叉点也是默认设置的。


3️⃣移动坐标轴

如果想要X轴的0点,和Y轴的0点交叉,需要使用set_position方法移动坐标轴的位置。


ax.spines['bottom'].set_position(('data', 0))

设置底边的移动范围,移动到Y轴的0位置

data:移动轴的位置到交叉轴的指定坐标。

运行下面的代码,移动X轴和Y轴到(0,0)点。


尝试下面的代码,移动X轴和Y轴到(0,0)点。

import matplotlib.pyplot as plt
import numpy as np
y = range(0,14,2) # x轴的位置
x = [-3,-2,-1,0,1,2,3]
# plt.figure(figsize=(20,8),dpi=80)
# 获得当前图表的图像
ax = plt.gca()
# 设置图型的包围线
ax.spines['right'].set_color('none')
ax.spines['top'].set_color('none')
ax.spines['bottom'].set_color('blue')
ax.spines['left'].set_color('red')
ax.spines['bottom'].set_position(('data', 2))
ax.spines['left'].set_position(('data', 1))
plt.plot(x,y)
plt.show()

✨效果

相关文章
|
2天前
|
数据可视化 数据挖掘 知识图谱
精选:15款顶尖Python知识图谱(关系网络)绘制工具,数据分析的强力助手
这里有15款免费工具推荐:NetworkX(Python基础),Graph-tool(C++速度),Graphviz(可视化库),ipycytoscape(Jupyter集成),ipydagred3,ipySigma(NetworkX + Web),Netwulf(交互式),nxviz(Matplotlib绑定),Py3plex(复杂网络分析),Py4cytoscape(Python+Cytoscape),pydot(Graphviz接口),PyGraphistry(GPU加速),python-igraph,pyvis(交互式图形),SNAP(大规模网络分析)。绘制和理解网络图从未如此简单!
10 0
|
3天前
|
机器学习/深度学习 自然语言处理 数据挖掘
使用Python和大模型进行数据分析和文本生成
Python语言以其简洁和强大的特性,成为了数据科学、机器学习和人工智能开发的首选语言之一。随着大模型(Large Language Models, LLMs)如GPT-4的崛起,我们能够利用这些模型实现诸多复杂任务,从文本生成到智能对话、数据分析等等。在这篇文章中,我将介绍如何用Python连接和使用大模型,并通过示例展示如何在实际项目中应用这些技术。
|
6天前
|
数据采集 机器学习/深度学习 数据可视化
利用Python和Pandas库构建高效的数据分析流程
在数据驱动的时代,数据分析已成为企业决策的关键环节。本文介绍如何利用Python编程语言及其强大的数据分析库Pandas,构建一套高效且可扩展的数据分析流程。与常规的数据分析流程不同,本文不仅涵盖数据加载、清洗、转换等基础步骤,还强调数据可视化、模型探索与评估等高级分析技巧,并通过实际案例展示如何在Python中实现这些步骤,为数据分析师提供一套完整的数据分析解决方案。
|
8天前
|
机器学习/深度学习 数据采集 数据可视化
使用Python进行数据分析涉及数据收集
【6月更文挑战第21天】使用Python进行数据分析涉及数据收集(如数据库、文件、API),数据清洗(处理缺失值、异常值和重复项),数据探索(统计摘要、可视化和相关性分析),特征工程(创建新特征和编码),模型构建(选择算法、训练与调整),模型评估(计算指标、可视化效果),结果解释(报告和可视化),以及部署与维护。此过程因项目需求而异,可能需迭代。常用库有`pandas`、`requests`、`BeautifulSoup`、`Matplotlib`等。
16 1
|
1天前
|
数据挖掘 Python
python数据分析常用图大集合
python数据分析常用图大集合
|
9天前
|
数据采集 数据可视化 数据挖掘
Python数据分析入门指南
Python数据分析涉及环境搭建(推荐Anaconda,含pandas和matplotlib库)。使用`pandas`读取CSV数据,如`data = pd.read_csv('data.csv')`。数据清洗包括检查缺失值(`data.isnull().sum()`)和处理异常值。然后进行数据处理,如创建新列、选择特定列及分组。利用`matplotlib`进行数据可视化,绘制直方图和散点图,以`plt.hist()`和`plt.scatter()`展示数据。
|
11天前
|
机器学习/深度学习 人工智能 算法框架/工具
Python赋能AI数据分析
Python赋能AI数据分析
27 0
|
16天前
|
机器学习/深度学习 数据采集 数据挖掘
如何用Python进行数据分析?
【6月更文挑战第13天】如何用Python进行数据分析?
116 66
|
13天前
|
数据采集 数据可视化 数据挖掘
数据挖掘实战:使用Python进行数据分析与可视化
在大数据时代,Python因其强大库支持和易学性成为数据挖掘的首选语言。本文通过一个电商销售数据案例,演示如何使用Python进行数据预处理(如处理缺失值)、分析(如销售额时间趋势)和可视化(如商品类别销售条形图),揭示数据背后的模式。安装`pandas`, `numpy`, `matplotlib`, `seaborn`后,可以按照提供的代码步骤,从读取CSV到数据探索,体验Python在数据分析中的威力。这只是数据科学的入门,更多高级技术等待发掘。【6月更文挑战第14天】
50 11
|
11天前
|
数据挖掘 数据库连接 Python
GitHub高赞!Python零基础也能搞定的数据分析与处理
经常会有人让我推荐一些 Python 入门教程。虽然 Python 入内教程到处都有,但是这些教程要么太宽泛(没有讲任何关于数据分析的内容),要么太专业(全是关于科学原理的内容)。然而Excel用户往往处在一个中间位置:他们的确是和数据打交道,但是科学原理对于他们来说可能又太专业了。他们常常有一些现有教程无法满足的特殊需求,举例如下 • 为完成某个任务,我应该用哪个 Python-Excel包? • 我如何将 Power Query 数据库连接迁移到 Python? • Excel中的 AutoFilter和数据透视表在 Python 中对应的是什么?

热门文章

最新文章