一、函数介绍
1
2
|
函数:twin()函数
含义:表示共享x轴,共享表示的就是x轴使用同一刻度
|
二、实际应用
2.1 实验数据展示
数据表的名称:600001sh.xlsx
2.2 代码实现:
文章里使用到了subplot()函数
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
# 导入相关数据包
import matplotlib.pyplot as plt
import pandas as pd
plt.rcparams[ 'font.sans-serif' ] = [ 'simhei' ] # 设置字体
plt.rcparams[ 'axes.unicode_minus' ] = false # 设置正负号
# 读取数据
path = '600001sh.xlsx'
df = pd.read_excel(path)
# 将日期设置为列索引
df.index = pd.to_datetime(df[ '日期' ])
# 得到2月的数据
feb_days = df[ '2015-02' ]
# 第一步,完成简单的单轴
x = feb_days.index.tolist() # 获取到x轴日期数据
y_1 = feb_days[ '开盘价(元)' ].values.tolist() # y轴数据1
y_2 = feb_days[ '成交量(股)' ].values.tolist() # y轴数据2
# 设置画板
fig = plt.figure(figsize = ( 10 , 8 ),dpi = 80 )
# 添加axes坐标轴实例,创建1个画板
ax = fig.add_subplot( 111 )
# 制作第一条折现
lin1 = ax.plot(x, y_1, label = '开盘价' , color = 'r' )
ax.set_xlabel( '日期' )
# 设置y轴1
ax.set_ylabel( '开盘价(元)' )
# 使用twinx()函数实现共用一个x轴
ax2 = ax.twinx()
# 制作第二条折现
lin2 = ax2.plot(x, y_2, label = '成交量' , color = 'green' )
# 设置y轴2
ax2.set_ylabel( '成交量(股)' )
# 合并图例
lines = lin1 + lin2
labs = [label.get_label() for label in lines]
ax.legend(lines,labs)
# 增加网格线
ax.grid()
plt.show()
|
2.3 最终结果显示
到此这篇关于基于python的matplotlib制作双y轴图的文章就介绍到这了,更多相关python制作双y轴图内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/Eli_change/article/details/115696518