具有自定义日期时间/时间戳值的Bokeh FixedTicker
问题内容:
目标:我想仅在2017/10/2和2017/10/5的x轴上有刻度线。一个约束是不能保证我的时间被平均分开,因此无法转换为字符串并进行分类轴。它们必须是数字/日期时间。
问题:我不确定如何正确格式化所需的日期,以便Bokeh正确呈现它们。我试过除以10 ** 9并转换为毫秒。这没有用。
样例代码:
from bokeh.plotting import figure, show
from bokeh.models import FixedTicker
import pandas as pd
import numpy as np
y = list(range(3))
x = [pd.Timestamp('2017-10-01'), pd.Timestamp('2017-10-09'), pd.Timestamp('2017-10-10')]
tick_vals = pd.Series([pd.Timestamp('2017-10-02'),
pd.Timestamp('2017-10-05')]).astype(np.int64)
tick_vals = tick_vals
tick_vals = tick_vals.astype(float)
fig = figure(x_axis_type='datetime')
fig.line(x, y, y_range_name=None)
fig.xaxis.ticker = FixedTicker(ticks=list(tick_vals)) # Commenting this line works okay using the x values. They are properly formatted.
show(fig)
版本:Bokeh:0.12.9 Pandas:0.20.3 Python:3.5.4 Numpy:1.13.3
问题答案:
将熊猫时间戳转换为整数可得到纳秒。因此,除以10 ^ 6得到毫秒对我来说是有效的:
y = list(range(3))
x = pd.to_datetime(['2017-10-01', '2017-10-09', '2017-10-10'])
tick_vals = pd.to_datetime(['2017-10-02', '2017-10-05']).astype(int) /
10**6
fig = figure(x_axis_type='datetime')
fig.line(x, y)
fig.xaxis.ticker = FixedTicker(ticks=list(tick_vals))
show(fig)