我有一个像这样的熊猫数据框
'A' 'B' 'C'
2018/1/1 10 20 20
2018/1/2 34 13 23
2018/1/3 23 45 43
2018/1/4 14 98 76
2018/1/5 58 65 57
如何将其转换为columnDataSource? 如何使用悬停工具在bokeh中创建多线图。 以X轴为日期
答案 0 :(得分:1)
进口:
import pandas as pd
from bokeh.models import ColumnDataSource, HoverTool
from bokeh.plotting import figure, show, output_notebook
output_notebook()
以下是您提供的数据:
days = ['2018/1/1', '2018/1/2', '2018/1/3', '2018/1/4', '2018/1/5']
data_a = [10, 34, 23, 14, 58]
data_b = [20, 13, 45, 98, 65]
data_c = [20, 23, 43, 76, 57]
创建DataFrame:
df_plot = pd.DataFrame({'A': data_a, 'B': data_b, 'C': data_c}, index=days)
A B C
2018/1/1 10 20 20
2018/1/2 34 13 23
2018/1/3 23 45 43
2018/1/4 14 98 76
2018/1/5 58 65 57
但是,索引不是正确的日期时间格式,因此请使用正确的格式创建日期列:
df_plot['dates'] = pd.to_datetime(df_plot.index, format='%Y/%m/%d')
A B C dates
2018/1/1 10 20 20 2018-01-01
2018/1/2 34 13 23 2018-01-02
2018/1/3 23 45 43 2018-01-03
2018/1/4 14 98 76 2018-01-04
2018/1/5 58 65 57 2018-01-05
现在进行绘图:
source = ColumnDataSource(df_plot)
p = figure(x_axis_type="datetime")
p.line('dates', 'A', source=source, color='red')
p.line('dates', 'B', source=source, color='blue')
p.line('dates', 'C', source=source, color='green')
p.add_tools(HoverTool(tooltips=[("A", "@A"), ("B", "@B"), ("C", "@C")]))
show(p)
这只是一个png,实际的输出将具有胡佛工具。