Этикетки Python Bokeh Tick
Я новичок в bokeh и пытаюсь нанести данные об акциях на линейный график. Ось X должна быть датами, а ось Y - ценой закрытия акций.
Вот пример моего кода:
data = pd.DataFrame({'Symbol' : ['AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD',],
'Previous_Close' : [10,20,30,10,20,30,10,20,30,10,20,30,10,20,30,10,20,30,],
'Date' : pd.to_datetime(['01/01/16', '01/01/16', '01/01/16', '01/02/16', '01/02/16', '01/02/16', '01/03/16', '01/03/16', '01/03/16', '01/04/16',
'01/04/16', '01/04/16', '01/05/16', '01/05/16', '01/05/16', '01/06/16', '01/06/16', '01/06/16'], format = '%m/%d/%y')})
Symbols = [sym for sym in data.Symbol.unique()]
Dates = [date for date in data.Date.unique()]
format_dates = [date.strftime('%b%d_%y') for date in dates]
colors = ['Darkred', 'Orange', 'Navy']
output_notebook()
TOOLS = ['hover','pan','box_zoom','resize', 'save', 'reset']
# CREATE FIGURE
p = figure(width = 800, height = 600, tools = TOOLS)
cnum = 0
# PLOT
for sym in Symbols:
# plot stock closing price
p.line(range(len(dates)), data[data.Symbol==sym].Previous_Close, color = colors[cnum])
# add stock symbol as text label to end of line
p.text(len(Symbols), data[data.Symbol==sym].Previous_Close.iloc[-1], [sym],
text_color = colors[cnum], text_font_size = '10pt')
cnum +=1
show(p)
Очевидно, что данные составлены здесь, но идея та же. Все, что я хочу, это установить метки x для обозначений форматированных названий дат. В Pyplot я бы просто сделал:
ax.set_xticklables(format_dates)
axis()
Я попытался установить x_axis_type в "datetime", но это дает мне только миллисекунды. Я пытался использовать DateTimeFormatter(), но либо я не понимаю, как его использовать, либо он не работает (возможно, первый).
Вещи, которые я испытал (RE ответы):
Это меняет ось x на миллисекунды: p = число (ширина = 800, высота = 600, x_axis_type='datetime', tools = TOOLS)
cnum = 0
# PLOT
for sym in Symbols:
# NO CHANGE TO X ARG
p.line(range(len(dates)), data[data.Symbol==sym].Previous_Close, color = colors[cnum])
Это меняет отметки x на десятилетия с 1970 года: p = число (ширина = 800, высота = 600, x_axis_type='datetime', tools = TOOLS)
cnum = 0
# PLOT
for sym in Symbols:
# CHANGE X ARG TO DATETIME DATES
p.line(dates, data[data.Symbol==sym].Previous_Close, color = colors[cnum])
2 ответа
Похоже, что ваша индексация панд вызывает проблемы. Я думаю, что этот код должен работать:
import numpy as np
import pandas as pd
from bokeh.plotting import figure, output_file, show
data = pd.DataFrame({'Symbol' : ['AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD','AMBA','FB','WWD',],
'Previous_Close' : [10,20,30,10,20,30,10,20,30,10,20,30,10,20,30,10,20,30,],
'Date' : pd.to_datetime(['01/01/16', '01/01/16', '01/01/16', '01/02/16', '01/02/16', '01/02/16', '01/03/16', '01/03/16', '01/03/16', '01/04/16', '01/04/16', '01/04/16', '01/05/16', '01/05/16', '01/05/16', '01/06/16', '01/06/16', '01/06/16'], format = '%m/%d/%y')})
symbols = [sym for sym in data.Symbol.unique()]
dates = [date for date in data.Date.unique()]
dates.sort()
lastDate = dates[-1]
colors = ['Darkred', 'Orange', 'Navy']
output_notebook()
TOOLS = ['hover','pan','box_zoom','resize', 'save', 'reset']
# CREATE FIGURE
p = figure(width = 800, height = 600, tools = TOOLS, x_axis_type="datetime")
# PLOT
for cnum, sym in enumerate(symbols):
# plot stock closing price
p.line(data[data.Symbol==sym].Date.values, data[data.Symbol==sym].Previous_Close.values, color = colors[cnum])
p.text(data[data.Date==lastDate].Date.values, data[data.Date==lastDate].Previous_Close.values, data[data.Date==lastDate].Symbol.values, text_color = colors, text_font_size = '10pt')
show(p)
Использовать:
p = figure(width = 800, height = 600, x_axis_type='datetime', tools = TOOLS)