python hist函数对不上_python – 无法使用hist()函数在日期时间对象的直方图中对齐bin...

所以我试图绘制一些日期时间对象的直方图,但我永远不能让垃圾箱与酒吧对齐.我的代码如下:

我首先导入我的东西并声明开始,结束和一天的对象:

import datetime

import matplotlib.pyplot as plt

end = datetime.date(2017,5,14)

start = datetime.date(2017,5,8)

one_day = datetime.timedelta(days = 1)

然后我宣布一个任意的日期列表:

date_list = [datetime.date(2017,5,14), datetime.date(2017,5,14),

datetime.date(2017,5,14), datetime.date(2017,5,9), datetime.date(2017,5,13),

datetime.date(2017,5,12), datetime.date(2017,5,11),

datetime.date(2017,5,11), datetime.date(2017,5,9)]

然后我会经历开始和结束之间的天数范围(在本例中为一周),将每个日期添加到列表中:

week = []

for i in range((end-start).days+1):

week.append(start + (i)*one_day)

原因是本周的某些日子没有出现在date_list中(我知道我可以在这种情况下跳过这个,但我希望它可以扩展到其他date_lists).

然后我用hist()绘图:

plt.hist(date_list, bins = len(week)+1)

plt.show()

我尝试过各种各样的bin格式组合,各种1和范围并且对齐,但日期从不坐在条形图中的一致位置.

解决方法:

如果只是设置箱的数量,则箱子将在(数据的)第一个和最后一个值之间平均分配.由于数据是例如错过起始值,垃圾箱将小于一整天.

为了克服这个问题,需要明确地将所需的bin设置为hist的bin参数.遗憾的是,这里不能直接使用日期时间列表,因此需要先将日期时间转换为数字.这可以使用matplotlib的matplotlib.dates.date2num方法完成.

完整的例子:

import datetime

import matplotlib.pyplot as plt

from matplotlib.dates import date2num

end = datetime.date(2017,5,14)

start = datetime.date(2017,5,8)

one_day = datetime.timedelta(days = 1)

date_list = [datetime.date(2017,5,14), datetime.date(2017,5,14),

datetime.date(2017,5,14), datetime.date(2017,5,9), datetime.date(2017,5,13),

datetime.date(2017,5,12), datetime.date(2017,5,11),

datetime.date(2017,5,11), datetime.date(2017,5,9)]

week = []

for i in range((end-start).days+1):

week.append(start + (i)*one_day)

numweek = date2num(week)

plt.hist(date_list, bins = numweek, ec="k")

plt.gcf().autofmt_xdate()

plt.show()

请注意,datetime.date(2017,5,14)是(2017,5,13)和(2017,5,14)之间的bin的一部分,因此您可能希望将enddate设置为

datetime.date(2017,5,15).

标签:python,datetime,matplotlib,histogram,bins

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值