Bokeh - Filtrage des données
Souvent, vous souhaiterez peut-être obtenir un tracé relatif à une partie des données qui satisfait à certaines conditions au lieu de l'ensemble de données. L'objet de la classe CDSView définie dans le module bokeh.models renvoie un sous-ensemble de ColumnDatasource considéré en appliquant un ou plusieurs filtres dessus.
IndexFilter est le type de filtre le plus simple. Vous devez spécifier les indices uniquement des lignes de l'ensemble de données que vous souhaitez utiliser lors du traçage de la figure.
L'exemple suivant illustre l'utilisation d'IndexFilter pour configurer un CDSView. La figure résultante montre un glyphe de ligne entre les séries de données x et y de ColumnDataSource. Un objet de vue est obtenu en appliquant un filtre d'index dessus. La vue est utilisée pour tracer le glyphe de cercle à la suite de IndexFilter.
Exemple
from bokeh.models import ColumnDataSource, CDSView, IndexFilter
from bokeh.plotting import figure, output_file, show
source = ColumnDataSource(data = dict(x = list(range(1,11)), y = list(range(2,22,2))))
view = CDSView(source=source, filters = [IndexFilter([0, 2, 4,6])])
fig = figure(title = 'Line Plot example', x_axis_label = 'x', y_axis_label = 'y')
fig.circle(x = "x", y = "y", size = 10, source = source, view = view, legend = 'filtered')
fig.line(source.data['x'],source.data['y'], legend = 'unfiltered')
show(fig)
Production
Pour choisir uniquement les lignes de la source de données qui satisfont à une certaine condition booléenne, appliquez un BooleanFilter.
Une installation Bokeh typique se compose d'un certain nombre d'exemples d'ensembles de données dans le répertoire sampledata. Pour l'exemple suivant, nous utilisonsunemployment1948ensemble de données fourni sous la forme de chômage1948.csv. Il stocke le pourcentage annuel de chômage aux Etats-Unis depuis 1948. Nous voulons générer un graphique uniquement pour l'année 1980 et après. Pour cela, un objet CDSView est obtenu en appliquant BooleanFilter sur la source de données donnée.
from bokeh.models import ColumnDataSource, CDSView, BooleanFilter
from bokeh.plotting import figure, show
from bokeh.sampledata.unemployment1948 import data
source = ColumnDataSource(data)
booleans = [True if int(year) >= 1980 else False for year in
source.data['Year']]
print (booleans)
view1 = CDSView(source = source, filters=[BooleanFilter(booleans)])
p = figure(title = "Unemployment data", x_range = (1980,2020), x_axis_label = 'Year', y_axis_label='Percentage')
p.line(x = 'Year', y = 'Annual', source = source, view = view1, color = 'red', line_width = 2)
show(p)
Production
Pour ajouter plus de flexibilité dans l'application du filtre, Bokeh fournit une classe CustomJSFilter à l'aide de laquelle la source de données peut être filtrée avec une fonction JavaScript définie par l'utilisateur.
L'exemple ci-dessous utilise les mêmes données sur le chômage aux États-Unis. Définition d'un CustomJSFilter pour tracer les chiffres du chômage de l'année 1980 et après.
from bokeh.models import ColumnDataSource, CDSView, CustomJSFilter
from bokeh.plotting import figure, show
from bokeh.sampledata.unemployment1948 import data
source = ColumnDataSource(data)
custom_filter = CustomJSFilter(code = '''
var indices = [];
for (var i = 0; i < source.get_length(); i++){
if (parseInt(source.data['Year'][i]) > = 1980){
indices.push(true);
} else {
indices.push(false);
}
}
return indices;
''')
view1 = CDSView(source = source, filters = [custom_filter])
p = figure(title = "Unemployment data", x_range = (1980,2020), x_axis_label = 'Year', y_axis_label = 'Percentage')
p.line(x = 'Year', y = 'Annual', source = source, view = view1, color = 'red', line_width = 2)
show(p)