首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用sharex的不同x值

使用sharex的不同x值
EN

Stack Overflow用户
提问于 2017-08-07 14:59:24
回答 1查看 202关注 0票数 2

我有两个索引系列,我想绘制它们并共享x轴(功能的范围包含X的范围):

代码语言:javascript
复制
import pandas as pd
import matplotlib.pyplot as plt
import datetime

start = pd.Timestamp('2017-01-01 08:00:00')
end = pd.Timestamp('2017-01-01 10:00:00')
X = pd.Series([1, 2, 3],
              [pd.Timestamp('2017-01-01 08:30:00'),
               pd.Timestamp('2017-01-01 09:30:00'),
               pd.Timestamp('2017-01-01 10:30:00')],
              )
FEATURE = pd.Series([0, 4, 2],
                    [pd.Timestamp('2017-01-01 08:00:00'),
                     pd.Timestamp('2017-01-01 09:00:00'),
                     pd.Timestamp('2017-01-01 10:00:00')]
                    )

f, (ax1, ax2) = plt.subplots(2, 1, sharex='all')
X[start:end].plot(ax=ax1)
FEATURE.plot(ax=ax2)
plt.show()

但只显示了特征。如果我把X放在最后,那么只显示X。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-08-08 12:22:07

一个可能的解决方案是用matplotlib绘制数据,而不是使用熊猫绘图包装。

代码语言:javascript
复制
import pandas as pd
import matplotlib.pyplot as plt
import matplotlib.dates as mdates

start = pd.Timestamp('2017-01-01 08:00:00')
end = pd.Timestamp('2017-01-01 10:00:00')
X = pd.Series([1, 2, 3],
              [pd.Timestamp('2017-01-01 08:30:00'),
               pd.Timestamp('2017-01-01 09:30:00'),
               pd.Timestamp('2017-01-01 10:30:00')],
              )
FEATURE = pd.Series([0, 4, 2],
                    [pd.Timestamp('2017-01-01 08:00:00'),
                     pd.Timestamp('2017-01-01 09:00:00'),
                     pd.Timestamp('2017-01-01 10:00:00')]
                    )

f, (ax1, ax2) = plt.subplots(2, 1, sharex='all') 

ax1.plot(X.index, X.values)
ax2.plot(FEATURE.index, FEATURE.values)

loc = mdates.MinuteLocator([0,30])
ax2.xaxis.set_major_locator(loc)
ax2.xaxis.set_major_formatter(mdates.AutoDateFormatter(loc))
plt.show()

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45550006

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档