AjaxDataSource
基类:bokeh.models.sources.WebSource
bokeh.models.sources.WebSource
可以通过对REST端点进行Ajax调用来填充列的数据源。
这个 AjaxDataSource 如果您想制作一个独立的文档(即不受Bokeh服务器的支持),它仍然可以使用现有的restapi进行动态更新,这一点尤其有用。
来自restapi的响应应该与 .data 标准的性质 ColumnDataSource ,即将名称映射到值数组的JSON dict:
.data
ColumnDataSource
{ 'x' : [1, 2, 3, ...], 'y' : [9, 3, 2, ...] }
或者,如果restapi返回不同的格式,则 CustomJS 可以提供回调,通过 adapter 属性。
CustomJS
adapter
初始数据可以通过指定 data 直接财产。当与 FactorRange ,即使 data `都是空的。
data
FactorRange
一个完整的例子可以在 examples/howto/ajax_source.py
属性类型: Instance ( CustomJS )
Instance
一个JavaScript回调,用于将原始JSON响应调整为Bokeh ColumnDataSource 格式。
如果提供了此回调,则在接收到JSON数据后立即执行,但在数据源中追加或替换数据之前。这个 CustomJS 回调将接收 AjaxDataSource 作为 cb_obj 并将接收原始JSON响应作为 cb_data.response . 回调代码应该返回一个 data 适合一个小木桶的物体 ColumnDataSource 列名称映射到列名称。
cb_obj
cb_data.response
content_type
属性类型: String
String
为Ajax请求设置“contentType”参数。
属性类型: ColumnData ( String , Seq ( Any ) )
ColumnData
Seq
Any
列名到数据序列的映射。列可以是Python列表或元组、NumPy数组等。
.data属性也可以从熊猫数据帧或GroupBy对象设置。在这些情况下,行为与将对象传递给 ColumnDataSource 初始值设定项。
data_url
要从中获取数据的URL。
http_headers
属性类型: Dict ( String , String )
Dict
指定要为Ajax请求设置的HTTP头。
例子:
ajax_source.headers = { 'x-my-custom-header': 'some value' }
if_modified
属性类型: Bool
Bool
是否包括 If-Modified-Since Ajax请求服务器的标头。如果服务器支持此标头,则将只返回上次请求以来的新数据。
If-Modified-Since
js_event_callbacks
属性类型: Dict ( String , List ( Instance ( CustomJS ) ) )
List
事件名称到列表的映射 CustomJS 回调。
通常,应该使用 Model.js_on_event 方法:
Model.js_on_event
callback = CustomJS(code="console.log('tap event occurred')") plot.js_on_event('tap', callback)
js_property_callbacks
属性名到列表的映射 CustomJS 回调,在创建文档时在BokehJS侧设置。
通常,应该使用 Model.js_on_change 方法:
Model.js_on_change
callback = CustomJS(code="console.log('stuff')") plot.x_range.js_on_change('start', callback)
max_size
属性类型: Int
Int
数据列的最大大小。如果新的获取将导致列大于 max_size ,然后删除先前的数据以腾出空间。
method
属性类型: Enum (枚举(POST,GET))
Enum
指定用于Ajax请求的HTTP方法(GET或POST)
mode
属性类型: Enum (枚举(replace,append))
是否将新数据附加到现有数据(最多 max_size )或完全替换现有数据。
name
用户为此模型提供的任意名称。
当查询文档以检索特定的Bokeh模型时,这个名称非常有用。
>>> plot.circle([1,2,3], [4,5,6], name="temp") >>> plot.select(name="temp") [GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]
注解
对于提供的任何名称,不提供唯一性保证或其他条件,Bokeh也不以任何理由直接使用该名称。
polling_interval
更新数据源的轮询间隔(毫秒)。
selected
属性类型: Instance ( Selection )
Selection
一个 Selection 它指示此上选定的索引 DataSource . 这是只读属性。您只能更改此对象的属性来更改选择(例如。, selected.indices )
DataSource
selected.indices
selection_policy
属性类型: Instance ( SelectionPolicy )
SelectionPolicy
一个 SelectionPolicy 它决定如何设置选择。
subscribed_events
属性类型: List ( String )
Python回调订阅的事件列表。对于这个模型,这是一组将从BokehJS传递回Python的事件。
tags
属性类型: List ( Any )
附加到此模型的任意用户提供的值的可选列表。
当查询文档以检索特定的Bokeh模型时,此数据非常有用:
>>> r = plot.circle([1,2,3], [4,5,6]) >>> r.tags = ["foo", 10] >>> plot.select(tags=['foo', 10]) [GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]
或者简单地将任何必要的元数据附加到可以通过 CustomJS 回调等。
对于所提供的任何标签,不存在唯一性保证或其他条件,Bokeh也不以任何理由直接使用这些标签。
__init__
如果使用单个参数调用,则该参数是dict或 pandas.DataFrame ,将其隐式处理为“data”属性。
pandas.DataFrame
add
向数据源追加新的数据列。
data (seq) -- 要添加的新数据
name (str, optional) -- 要使用的列名。如果未提供,则生成格式为“Series######”
使用的列名
str
apply_theme
应用一组主题值,这些值将被使用而不是默认值,但不会覆盖应用程序集值。
传入的字典可以保持原样,并与其他实例共享以节省内存(因此无论是调用方还是 HasProps 实例应该修改它)。
HasProps
property_values (dict) -- 主题值用于替代默认值
没有
dataspecs
收集所有人的名字 DataSpec 类的属性。
DataSpec
这种方法 总是 遍历类层次结构并包含在任何父类上定义的属性。
名称 DataSpec 性质
set[str]
dataspecs_with_props
收集一张记录所有人姓名的字典 DataSpec 类的属性。
名称和 DataSpec 性质
dict[str, DataSpec]
equals
模型的结构相等。
other (HasProps) -- 要比较的另一个实例
如果属性在结构上相等,则为True,否则为False
from_df
创建一个 dict 一只熊猫的柱子 DataFrame ,适合创建 ColumnDataSource .
dict
DataFrame
data (DataFrame) -- 要转换的数据
双关语 [结构,np.数组]
from_groupby
创建一个 dict 一只熊猫的柱子 GroupBy ,适合创建 ColumnDataSource .
GroupBy
生成的数据是运行的结果 describe 在小组里。
describe
data (Groupby) -- 要转换的数据
js_link
使用JavaScript链接两个Bokeh模型属性。
这是一种方便的方法,它简化了添加一个CustomJS回调,以便在另一个Bokeh模型属性更改值时更新它。
attr (str) -- 此模型上的Bokeh属性的名称
other (Model) -- 要链接到的Bokeh模型自我属性
other_attr (str) -- 上的财产 other 连接在一起
other
attr_selector (Union[int, str]) -- 链接可订阅项中的项的索引 attr
attr
在版本1.1中添加
ValueError --
实际案例
此代码与 js_link :
select.js_link('value', plot, 'sizing_mode')
相当于:
from bokeh.models import CustomJS select.js_on_change('value', CustomJS(args=dict(other=plot), code="other.sizing_mode = this.value" ) )
此外,要使用属性选择器将范围滑块的左侧附加到绘图的x_范围:
range_slider.js_link('value', plot.x_range, 'start', attr_selector=0)
from bokeh.models import CustomJS range_slider.js_on_change('value', CustomJS(args=dict(other=plot.x_range), code="other.start = this.value[0]" ) )
js_on_change
附A CustomJS 对任意BokehJS模型事件的回调。
在BokehJS方面,模型属性的更改事件具有以下形式 "change:property_name" . 为了方便起见,如果传递给此方法的事件名也是模型上某个属性的名称,那么它的前缀将是 "change:" 自动:
"change:property_name"
"change:"
# these two are equivalent source.js_on_change('data', callback) source.js_on_change('change:data', callback)
但是,除了属性更改事件之外,还有其他类型的事件可以用来响应。例如,每当数据流式传输到 ColumnDataSource 使用 "stream" 源上的事件:
"stream"
source.js_on_change('streaming', callback)
layout
lookup
找到 PropertyDescriptor 对于类上的Bokeh属性,给定属性名。
PropertyDescriptor
name (str) -- 要搜索的属性的名称
名为的属性的描述符 name
on_change
在此对象上添加回调以在 attr 变化。
attr (str) -- 此对象的属性名
*callbacks (callable) -- 要注册的回调函数
widget.on_change('value', callback1, callback2, ..., callback_n)
patch
有效地更新特定位置的数据源列
如果只需要更新 ColumnDataSource ,这种方法可以有效地只更新子集,而不需要发送整个数据集。
应该向此方法传递一个字典,该字典将列名映射到描述要应用的修补程序更改的元组列表。要完全替换列中的单个项,元组的格式应为:
(index, new_value) # replace a single column value # or (slice, new_values) # replace several column values
索引或切片中的值将替换为相应的新值。
对于值为其他数组或列表的列(例如图像或面片图示符),也可以修补“子区域”。在这种情况下,元组的第一项应该是,其第一个元素是CDS修补程序中数组项的索引,其后续元素是整数索引或数组项的切片:
# replace the entire 10th column of the 2nd array: +----------------- index of item in column data source | | +--------- row subindex into array item | | | | +- column subindex into array item V V V ([2, slice(None), 10], new_values)
想象一下2d NumPy数组的列表,上面的补丁大致相当于:
data = [arr1, arr2, ...] # list of 2d arrays data[2][:, 10] = new_data
对于可以接受的切片和数据的种类有一些限制。
否定的 start , stop 或 step 切片的值将导致 ValueError .
start
stop
step
ValueError
一片一片, start > stop 会导致 ValueError
start > stop
当修补1d或2d子项时,子项必须是NumPy数组。
新值必须作为 flattened one-dimensional array 大小合适的。
patches (dict[str, list[tuple]]) -- 每列的修补程序列表
下面的示例演示如何修补整个列元素。在这种情况下,
source = ColumnDataSource(data=dict(foo=[10, 20, 30], bar=[100, 200, 300])) patches = { 'foo' : [ (slice(2), [11, 12]) ], 'bar' : [ (0, 101), (2, 301) ], } source.patch(patches)
此操作之后 source.data 将:
source.data
dict(foo=[11, 12, 30], bar=[101, 200, 301])
有关更全面的完整示例,请参见 examples/howto/patch_app.py .
properties
收集此类的属性名称。
这种方法 任选地 遍历类层次结构并包含在任何父类上定义的属性。
with_bases (bool, optional) -- 是否在结果中包含在父类上定义的属性。(默认值:True)
属性名称
properties_containers
收集此类上所有容器属性的名称。
容器属性名称
properties_with_refs
收集该类上也有引用的所有属性的名称。
具有引用的属性的名称
properties_with_values
收集将属性名称映射到其值的dict。
跳过不可序列化的属性,属性值采用“序列化”格式,这可能与通常从属性中读取的值略有不同;此方法的目的是返回无损重建对象实例所需的信息。
include_defaults (bool, optional) -- 是否包含自创建对象后尚未显式设置的属性。(默认值:True)
从属性名到属性值的映射
query_properties_with_values
查询的属性值 HasProps 带有谓词的实例。
query (callable) -- 接受属性描述符并返回True或False的可调用文件
include_defaults (bool, optional) -- 是否包含尚未由用户显式设置的属性(默认值:True)
为匹配的属性映射属性名称和值
references
返回全部 Models 此对象引用的。
Models
remove
删除一列数据。
name (str) -- 要删除的列的名称
如果列名不存在,将发出警告。
remove_on_change
从此对象中删除回调
select
查询此对象及其所有引用以查找与给定选择器匹配的对象。
selector (JSON-like) --
SEQ [模型]
select_one
查询此对象及其所有引用以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配的对象,如果找不到任何对象,则返回无:param selector::type selector:JSON like
模型
set_from_json
从JSON设置此对象的属性值。
name -- (str):要设置的属性的名称
json -- (JSON value):要设置为的属性的值
models (dict or None, optional) -- 模型ID到模型的映射(默认值:无)在要更新的属性也有引用的值的情况下,需要这样做。
setter (ClientSession or ServerSession or None, optional) -- 这是用来防止“飞镖”更新到博克应用程序。在Bokeh服务器应用程序的上下文中,对属性的传入更新将使用正在进行更新的会话进行注释。此值通过更新触发的任何后续更改通知传播。会话可以将事件设置程序与其自身进行比较,并禁止任何源自自身的更新。
set_select
更新与具有指定属性/值的给定选择器匹配的对象将更新。
updates (dict) --
stream
使用新的仅附加数据高效地更新数据源列。
在需要更新中的数据列的情况下,此方法可以有效地仅发送新数据,而不需要重新发送整个数据集。
new_data (dict[str, seq]) -- 列名到要附加到每个列的新数据序列的映射。数据源的所有列都必须存在于 new_data ,具有相同长度的附加数据。
new_data
rollover (int, optional) -- 列大小的最大值,超过该值,从列开始的数据开始被丢弃。如果没有,则列将继续无限增长(默认值:无)
source = ColumnDataSource(data=dict(foo=[], bar=[])) # has new, identical-length updates for all columns in source new_data = { 'foo' : [10, 20], 'bar' : [100, 200], } source.stream(new_data)
themed_values
获取任何主题提供的覆盖。
结果以dict形式从属性名返回到值,或者 None 如果没有主题覆盖此实例的任何值。
None
不记名
to_df
将此数据源转换为pandas DataFrame .
to_json
返回此对象属性的字典,只包含“JSON类型”(string、number、boolean、none、dict、list)。
对其他对象的引用被序列化为“refs”(只是对象ID和类型信息),因此反序列化程序需要单独拥有这些其他对象的完整属性。
没有对应的 from_json() 因为反序列化对象通常是在文档上下文中完成的(因为文档可以解析引用)。
from_json()
在大多数情况下,最好序列化和反序列化整个文档。
include_defaults (bool) -- 是否包含未从默认值更改的属性
to_json_string
返回编码此对象属性的JSON字符串。
对其他对象的引用被序列化为引用(仅对象ID和类型信息),因此反序列化程序将需要单独拥有这些其他对象的完整属性。
没有对应的 from_json_string() 因为反序列化对象通常是在文档上下文中完成的(因为文档可以解析引用)。
from_json_string()
trigger
unapply_theme
删除所有主题值并恢复默认值。
update
从给定的关键字参数更新对象的属性。
以下是等效的:
from bokeh.models import Range1d r = Range1d # set properties individually: r.start = 10 r.end = 20 # update properties together: r.update(start=10, end=20)
update_from_json
对象的属性从字典中更新。
json_attributes -- (JSON dict):要更新的属性和值
column_names
此数据源中列名的列表。
document
这个 Document 此模型附加到(可以是 None )
Document
struct
此模型的Bokeh协议“结构”,即以下形式的dict:
{ 'type' : << view model name >> 'id' : << unique model id >> }
此外,可能还有 subtype 字段(如果此模型是子类型)。
{ "adapter": null, "content_type": "application/json", "data": {}, "data_url": null, "http_headers": {}, "id": "8023", "if_modified": false, "js_event_callbacks": {}, "js_property_callbacks": {}, "max_size": null, "method": "POST", "mode": "replace", "name": null, "polling_interval": null, "selected": { "id": "8025" }, "selection_policy": { "id": "8024" }, "subscribed_events": [], "tags": [] }
CDSView
基类:bokeh.model.Model
bokeh.model.Model
一个 ColumnDataSource 表示按行排列的子集。
filters
属性类型: List ( Instance ( Filter ) )
Filter
视图包含的筛选器列表。
source
属性类型: Instance ( ColumnarDataSource )
ColumnarDataSource
这个 ColumnDataSource 与此视图关联。用于确定列的长度。
{ "filters": [], "id": "8043", "js_event_callbacks": {}, "js_property_callbacks": {}, "name": null, "source": null, "subscribed_events": [], "tags": [] }
基类:bokeh.models.sources.ColumnarDataSource
bokeh.models.sources.ColumnarDataSource
将列的名称映射到序列或数组。
这个 ColumnDataSource 是Bokeh的一个基本数据结构。大多数绘图、数据表等将由 ColumnDataSource .
如果 ColumnDataSource 使用可以是以下任意一个参数的单个参数调用初始值设定项:
Python dict 它将字符串名称映射到值序列,例如列表、数组等。
data = {'x': [1,2,3,4], 'y': np.ndarray([10.0, 20.0, 30.0, 40.0])} source = ColumnDataSource(data)
ColumnDataSource 只创建 data . 使用例如。 ColumnDataSource(copy.deepcopy(data)) 如果从另一个初始化 ColumnDataSource.data 要保持独立的对象。
ColumnDataSource(copy.deepcopy(data))
ColumnDataSource.data
熊猫 DataFrame 对象
source = ColumnDataSource(df)
在这种情况下,cd的列将与 DataFrame . 如果 DataFrame 列有多个级别,将使用下划线将其展平(例如level_0_col_level_1_col)。的索引 DataFrame 将被夷为平地 Index 如果是一个元组 MultiIndex ,然后使用 reset_index . 如果索引是命名的,结果将是一个同名的列;如果索引是命名的,则结果将是一个同名的列;如果索引是命名的,则结果将是一个具有相同名称的列 MultiIndex . 如果 Index 没有名字或者 MultiIndex 无法展开/确定名称 reset_index 函数将命名索引列 index 或 level_0 如果名字 index 不可用。
Index
MultiIndex
reset_index
index
level_0
熊猫 GroupBy 对象
group = df.groupby(('colA', 'ColB'))
在这种情况下,cd将具有与调用结果相对应的列 group.describe() . 这个 describe 方法为统计度量生成列,例如 mean 和 count 对于所有未分组的原始列。CDS列是通过将原始列名与计算出的度量值连接起来形成的。例如,如果 DataFrame 有列 'year' 和 'mpg' . 然后就过去了 df.groupby('year') 到一个CD将导致列,如 'mpg_mean'
group.describe()
mean
count
'year'
'mpg'
df.groupby('year')
'mpg_mean'
如果 GroupBy.describe 结果有一个命名的索引列,那么CDS也会有一个同名的列。但是,如果索引名称(或 MultiIndex 是 None ,则cd将有一个列,该列通常命名为 index 用于索引。
GroupBy.describe
注意这种适应能力 GroupBy 物体只能和熊猫一起使用 >=0.20.0 .
>=0.20.0
有一个隐含的假设,即 ColumnDataSource 在任何时候都有相同的长度。因此,通常最好更新 .data 数据源的属性“立即全部”。
{ "data": {}, "id": "8051", "js_event_callbacks": {}, "js_property_callbacks": {}, "name": null, "selected": { "id": "8053" }, "selection_policy": { "id": "8052" }, "subscribed_events": [], "tags": [] }
基类:bokeh.models.sources.DataSource
bokeh.models.sources.DataSource
数据源类型的基类,可以映射到列格式。
这是一个抽象基类,用于帮助组织Bokeh模型类型的层次结构。 单独实例化是没有用的。
{ "id": "8062", "js_event_callbacks": {}, "js_property_callbacks": {}, "name": null, "selected": { "id": "8064" }, "selection_policy": { "id": "8063" }, "subscribed_events": [], "tags": [] }
数据源的基类型。
{ "id": "8072", "js_event_callbacks": {}, "js_property_callbacks": {}, "name": null, "selected": { "id": "8073" }, "subscribed_events": [], "tags": [] }
GeoJSONDataSource
geojson
属性类型: JSON
JSON
包含绘图功能的GeoJSON。目前 GeoJSONDataSource 只能处理a FeatureCollection 或 GeometryCollection .
FeatureCollection
GeometryCollection
{ "geojson": null, "id": "8080", "js_event_callbacks": {}, "js_property_callbacks": {}, "name": null, "selected": { "id": "8082" }, "selection_policy": { "id": "8081" }, "subscribed_events": [], "tags": [] }
ServerSentDataSource
可以通过接收服务器发送的事件终结点填充列的数据源。
{ "adapter": null, "data": {}, "data_url": null, "id": "8091", "js_event_callbacks": {}, "js_property_callbacks": {}, "max_size": null, "mode": "replace", "name": null, "selected": { "id": "8093" }, "selection_policy": { "id": "8092" }, "subscribed_events": [], "tags": [] }
WebSource
基类:bokeh.models.sources.ColumnDataSource
bokeh.models.sources.ColumnDataSource
可从数据URL更新的web列数据源的基类。
这个基类对于单独实例化通常是没有用的。
{ "adapter": null, "data": {}, "data_url": null, "id": "8106", "js_event_callbacks": {}, "js_property_callbacks": {}, "max_size": null, "mode": "replace", "name": null, "selected": { "id": "8108" }, "selection_policy": { "id": "8107" }, "subscribed_events": [], "tags": [] }