JNe*_*ens 4 python matplotlib pandas
我有一个看起来像这样的DataFrame:
####delays:
Worst case Avg case
2014-10-27 2.861433 0.953108
2014-10-28 2.899174 0.981917
2014-10-29 3.080738 1.030154
2014-10-30 2.298898 0.711107
2014-10-31 2.856278 0.998959
2014-11-01 3.118587 1.147104
...
Run Code Online (Sandbox Code Playgroud)
我想绘制这个DataFrame的数据,以及数据的滚动平均值.我想数据本身应该是一个虚线,滚动意味着是一个完整的行.最坏情况列应为红色,而平均情况列应为蓝色.
我试过以下代码:
import pandas as pd
import matplotlib.pyplot as plt
rolling = pd.rolling_mean(delays, 7)
delays.plot(x_compat=True, style='r--')
rolling.plot(style='r')
plt.title('Delays per day on entire network')
plt.xlabel('Date')
plt.ylabel('Minutes')
plt.show()
Run Code Online (Sandbox Code Playgroud)
不幸的是,这给了我两个不同的情节.一个是数据,另一个是滚动平均值.此外,最坏情况列和平均情况列都是红色.
我怎样才能让它发挥作用?
你需要对你想要绘图的熊猫说.默认情况下,pandas会创建一个新数字.
只需修改这两行:
delays.plot(x_compat=True, style='r--')
rolling.plot(style='r')
Run Code Online (Sandbox Code Playgroud)
通过:
ax_delays = delays.plot(x_compat=True, style='--', color=["r","b"])
rolling.plot(color=["r","b"], ax=ax_delays, legend=0)
Run Code Online (Sandbox Code Playgroud)
在第二行,你现在告诉大熊猫在ax_delays上绘图,并且不再显示图例.
要为2条线获得2种不同的颜色,只需使用color
参数传递尽可能多的颜色(参见上文).
归档时间: |
|
查看次数: |
5474 次 |
最近记录: |