使用海运在 pandas 盒子图上保持工作日订单
问题描述
我有一个简单的数据集,上面有天数:
dt, value, coltype
2017-01-01, 10, A
2017-01-02, 11, B
2017-01-03, 30, A
2017-01-04, 90, C
2017-01-05, 9, A
2017-01-06, 13, E
2017-01-07, 12, C
2017-01-08, 10, B
我想创建一个简单的基于工作日的框图:
import seaborn as sns
import pandas as pd
df = read_csv('mycsv.txt')
df.index = pd.to_datetime(df.dt)
sns.boxplot(x=df.index.weekday_name, y=value)
我得到的是一个框图,但没有按工作日排序:
是否可以直接在boxlot函数上执行此操作,而无需创建另一个列?
解决方案
使用order
参数:
order = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"]
sns.boxplot(x=df.index.weekday_name, y=df.value, order=order)
如果您的日期是完整的,并且包含每个工作日的数据,您将得到如下内容:
如果假设您没有某一工作日的数据,但仍然调用相同的代码,则会得到如下内容:
这完全没问题(至少对我来说是这样),而且您还可以清楚地看到周二没有数据,这也可以告诉您有关数据的更多信息。
相关文章