用于分类数据的跳跃记号标签

2022-04-07 00:00:00 python bokeh

问题描述

我正在使用Bokeh版本0.12.13。 我有一个混合了数字和绝对数据的数据。我只有一个关于x轴的分类数据,其余的都是数字数据。我把所有东西都转换成分类数据来做绘图(可能不是实现我目标的最容易的方法)。现在我的x轴刻度标签比我需要的要密集得多。我想每隔10个值将它们隔开,这样标签就是10、20、...、90、Rest

这是我到目前为止尝试的内容:

import pandas as pd
from bokeh.io import show
from bokeh.models import ColumnDataSource
from bokeh.plotting import figure
from bokeh.models.tickers import FixedTicker

# create mock data
n = [str(i) for i in np.arange(1,100)]
n.append('rest')
t = pd.DataFrame([n,list(np.random.randint(25,size=100))]).T
t.columns = ['Number','Value']
t.loc[t['Number']==100,'Number'] = 'Rest'

source = ColumnDataSource(t)

p = figure(plot_width=800, plot_height=400, title="",
            x_range=t['Number'].tolist(),toolbar_location=None, tools="")

p.vbar(x='Number', top='Value', width=1, source=source,
       line_color="white")

#p.xaxis.ticker = FixedTicker(ticks=[i for i in range(0,100,10)])

show(p)

理想情况下,我希望网格和x轴标签每隔10个值出现一次。任何关于如何实现这一目标的帮助都将受到极大的感谢。


解决方案

更简单的方法是保留数字数据并使用xaxis.main_LABEL_OVERRIDES。代码如下:

import pandas as pd
from bokeh.io import show
from bokeh.models import ColumnDataSource
from bokeh.plotting import figure
from bokeh.models.tickers import FixedTicker

# create mock data
n = np.arange(1,101)
t = pd.DataFrame([n,list(np.random.randint(25,size=100))]).T
t.columns = ['Number','Value']

source = ColumnDataSource(t)

p = figure(plot_width=800, plot_height=400, title="",
            toolbar_location=None, tools="")

p.vbar(x='Number', top='Value', width=1, source=source,
       line_color="white")

p.xaxis.major_label_overrides = {100: 'Rest'}

show(p)

相关文章