首页 > 解决方案 > 绘制数小时内每列数据帧的最大值

问题描述

我有一个每月时间序列数据(5 分钟),其中每天是一列,每 5 分钟是一行,所以形状是(288,30)。我想将所有数据绘制为具有低 alpha 的细线。此外,在同一张图上,我想将它们各自时间 ID 上的最大值绘制为粗点,以说明它们出现的位置。

我已经尝试了下面的代码,但无法将 timeindex 轴与最大值的 ID 链接起来。


import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

df = pd.DataFrame(np.random.randint(0,100,size=(8640, 1)),index=pd.date_range(start="20180301", freq='5T',periods=8640),columns=['A'])

df_all_days=df.groupby(df.index.time).aggregate(lambda x:list(x))
df_all_days_exp=df_all_days.apply(pd.Series)

df_all_days_exp_Max=df_all_days_exp.max(axis=0)
df_all_days_exp_MaxID=df_all_days_exp.idxmax(axis=0)
df_all_days_exp_Max_ID=pd.DataFrame([df_all_days_exp_Max,df_all_days_exp_MaxID]).T

plt.figure()
plt.plot(df_all_days_exp,linewidth=0.3,alpha=0.4)
plt.plot(df_all_days_exp_Max_ID,'.k',linewidth=1.5)

标签: pythonpandasdataframepandas-groupby

解决方案


IIUC,你可以试试:

hour_df = df.resample('H').max()

fig, ax = plt.subplots(figsize=(10,6))

df.plot(ax=ax, alpha=0.1)

ax2 = ax.twiny()
ax2.scatter(range(len(hour_df)), hour_df, c='r')
ax2.set_xticks([])

plt.show()

输出: 在此处输入图像描述


推荐阅读