工具#

Bokeh 配备了许多交互式工具。

共有五种类型的工具交互

  • 平移/拖动

  • 点击/轻触

  • 滚动/捏合

  • 操作

  • 检查器

前三种构成手势工具类别,并且在任何给定时间,每种手势只能激活一个工具。活动工具在工具栏上通过工具旁边的突出显示来指示。操作是立即的或模态的操作,仅当按下工具栏中的按钮时才激活。检查器是被动工具,仅报告信息或以某种方式注释绘图,并且无论当前激活了哪些其他工具,都可以始终处于活动状态。

class ActionTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Tool

工具栏中按钮工具的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65372", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class BoxEditTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类:EditToolDragTap

工具栏图标工具栏中表示框编辑工具的实线框,右下角带加号的图标。

允许通过编辑底层 ColumnDataSource 数据在一个或多个渲染器上绘制、拖动和删除类似框形的字形(例如 BlockRectHStrip)。与其他绘图工具一样,要编辑的渲染器必须显式地作为列表提供。绘制新框时,数据将始终添加到第一个提供的渲染器上的 ColumnDataSource

该工具将修改数据源上与字形的 xywidthheight 值相对应的列。添加新框时,数据源中的任何其他列都将填充 empty_value

支持的操作包括

  • 添加框:按住 Shift 键,然后在绘图上的任意位置单击并拖动,或者按一次开始绘制,移动鼠标,然后再次按以完成绘制。

  • 移动框:单击并拖动现有框,松开鼠标按钮后,框将放下。

  • 删除框:点击一个框以选中它,然后在鼠标位于绘图区域内时按退格键。

要一次移动删除多个框

  • 移动选择:使用 SHIFT+点击(或其他选择工具)选择框,然后在绘图上的任意位置拖动。选择然后在特定框上拖动将移动两者。

  • 删除选择:使用 SHIFT+点击(或其他选择工具)选择框,然后在鼠标位于绘图区域内时按退格键。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "dimensions": "both", 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65380", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "num_objects": 0, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

框绘制要在哪些维度上自由进行。默认情况下,用户可以自由绘制任何维度的框。如果仅设置“width”,则框将限制为跨越绘图的整个垂直空间,只能控制水平维度。如果仅设置“height”,则框将限制为跨越绘图的整个水平空间,并且可以控制垂直维度。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

num_objects = 0#
类型:

Int

定义可以绘制的框数量的限制。默认情况下,对象数量没有限制,但如果启用,则将删除最旧的绘制框,以便为要添加的新框腾出空间。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class BoxSelectTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: Drag, RegionSelectTool

toolbar icon: 工具栏中代表框选工具的虚线框,右下角带 + 号图标

框选工具允许用户在绘图上进行选择,方法是在绘图区域上拖动鼠标或手指来显示一个矩形区域。拖动事件结束时,表示选择区域已准备就绪。

有关样式化选定和未选定字形的信息,请参阅选定和未选定字形

JSON 原型
{
  "continuous": false, 
  "description": null, 
  "dimensions": "both", 
  "greedy": false, 
  "group": true, 
  "icon": null, 
  "id": "p65393", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "mode": "replace", 
  "name": null, 
  "origin": "corner", 
  "overlay": {
    "attributes": {
      "bottom": {
        "type": "number", 
        "value": "nan"
      }, 
      "editable": true, 
      "fill_alpha": 0.5, 
      "fill_color": "lightgrey", 
      "handles": {
        "attributes": {
          "all": {
            "attributes": {
              "fill_color": "white", 
              "hover_fill_color": "lightgray"
            }, 
            "id": "p65399", 
            "name": "AreaVisuals", 
            "type": "object"
          }
        }, 
        "id": "p65400", 
        "name": "BoxInteractionHandles", 
        "type": "object"
      }, 
      "left": {
        "type": "number", 
        "value": "nan"
      }, 
      "level": "overlay", 
      "line_alpha": 1.0, 
      "line_color": "black", 
      "line_dash": [
        4, 
        4
      ], 
      "line_width": 2, 
      "right": {
        "type": "number", 
        "value": "nan"
      }, 
      "syncable": false, 
      "top": {
        "type": "number", 
        "value": "nan"
      }, 
      "visible": false
    }, 
    "id": "p65394", 
    "name": "BoxAnnotation", 
    "type": "object"
  }, 
  "persistent": false, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
continuous = False#
类型:

Bool

是否应在选择手势期间连续进行选择计算,还是仅在选择区域完成时进行一次。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

框选在哪些维度上是自由的。 默认情况下,用户可以自由绘制任意尺寸的选择框。 如果仅设置“宽度”,则框将被约束为跨越绘图的整个垂直空间,只有水平维度可以控制。 如果仅设置“高度”,则框将被约束为跨越绘图的整个水平空间,并且垂直维度可以控制。

greedy = False#
类型:

Bool

定义点击字形时,是需要完全包含在选择区域内(非贪婪),还是仅需要相交(贪婪)(即,至少有一个点在区域内)。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

mode = 'replace'#
类型:

Enum(RegionSelectionMode)

定义在进行新选择时应发生什么。 默认是替换现有选择。 其他选项是追加到选择、与之相交或从中减去。

定义在进行新选择时应发生什么。

默认是替换现有选择。 其他选项是追加到选择、与之相交、从中减去或计算与它的对称差。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

origin = 'corner'#
类型:

Enum(Enumeration(corner, center))

指示矩形选择区域应从角(左上角或右下角,取决于方向)还是框的中心开始。

overlay = BoxAnnotation(id='p65481', ...)#
类型:

Instance(BoxAnnotation)

一个阴影注释,用于指示选择区域。

persistent = False#
类型:

Bool

选择叠加层是否应在选择手势完成后保持存在。 这可以与在注释上设置 editable = True 结合使用,以允许修改选择。

renderers = 'auto'#
类型:

Either(Auto, List)

要进行点击测试的渲染器列表。 如果未设置,则默认为绘图上的所有渲染器。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

select_every_mousemove#

这是 ‘continuous’ 属性的向后兼容性别名。

注意

属性 ‘select_every_mousemove’ 在 Bokeh 3.1.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘continuous’ 替代。

class BoxZoomTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Drag

工具栏图标: 工具栏中表示框选缩放工具的右上角带有放大镜的虚线框图标。

框选缩放工具允许用户通过在绘图区域上拖动鼠标或手指来定义要缩放到的绘图矩形区域。拖动事件结束时表示选择区域已准备就绪。

注意

BoxZoomToolGMapPlot 不兼容,因为 Google Maps 以显式控制宽高比的方式运行。将此工具添加到 GMapPlot 将不起作用。

JSON 原型
{
  "description": null, 
  "dimensions": "auto", 
  "group": true, 
  "icon": null, 
  "id": "p65528", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "match_aspect": false, 
  "name": null, 
  "origin": "corner", 
  "overlay": {
    "attributes": {
      "bottom": {
        "type": "number", 
        "value": "nan"
      }, 
      "bottom_units": "canvas", 
      "fill_alpha": 0.5, 
      "fill_color": "lightgrey", 
      "handles": {
        "attributes": {
          "all": {
            "attributes": {
              "fill_color": "white", 
              "hover_fill_color": "lightgray"
            }, 
            "id": "p65534", 
            "name": "AreaVisuals", 
            "type": "object"
          }
        }, 
        "id": "p65535", 
        "name": "BoxInteractionHandles", 
        "type": "object"
      }, 
      "left": {
        "type": "number", 
        "value": "nan"
      }, 
      "left_units": "canvas", 
      "level": "overlay", 
      "line_alpha": 1.0, 
      "line_color": "black", 
      "line_dash": [
        4, 
        4
      ], 
      "line_width": 2, 
      "right": {
        "type": "number", 
        "value": "nan"
      }, 
      "right_units": "canvas", 
      "syncable": false, 
      "top": {
        "type": "number", 
        "value": "nan"
      }, 
      "top_units": "canvas", 
      "visible": false
    }, 
    "id": "p65529", 
    "name": "BoxAnnotation", 
    "type": "object"
  }, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'auto'#
类型:

Either(Enum(Dimensions), Auto)

缩放框在哪些维度上可以自由移动。默认情况下,用户可以自由绘制任意维度的缩放框。如果仅提供 “width”,则框将被约束为跨越绘图的整个垂直空间,只有水平维度可以控制。如果仅提供 “height”,则框将被约束为跨越绘图的整个水平空间,并且垂直维度可以控制。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

match_aspect = False#
类型:

Bool

框选缩放区域是否应限制为与绘图区域具有相同的宽高比。

注意

如果该工具被限制在一个维度上,则此值无效。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

origin = 'corner'#
类型:

Enum(Enumeration(corner, center))

指示矩形缩放区域应从角(取决于方向,左上角或右下角)还是框的中心开始。

overlay = BoxAnnotation(id='p65600', ...)#
类型:

Instance(BoxAnnotation)

一个阴影注释,用于指示选择区域。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, **callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, **callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], **callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, **callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ClickPanTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PlotActionTool

一个工具,允许通过单击按钮以固定量平移绘图。

JSON 原型
{
  "description": null, 
  "direction": {
    "name": "unset", 
    "type": "symbol"
  }, 
  "factor": 0.1, 
  "group": true, 
  "icon": null, 
  "id": "p65631", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

direction = Undefined#
类型:

Required(Enum(PanDirection))

平移绘图的方向。

可接受的值为 "left""right""up""down",或它们各自的别名 "west""east""north""south"

factor = 0.1#
类型:

百分比

每次使用该工具时平移范围的百分比。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class CopyTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ActionTool

toolbar icon: copy_icon

CopyTool 是一个动作工具,允许将绘图或一组绘图的渲染内容复制到系统的剪贴板。此工具依赖于浏览器,可能在某些浏览器中无法运行,或者需要授予网页额外的权限。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65641", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class CrosshairTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: InspectTool

toolbar icon: 工具栏中代表十字准星工具的带瞄准线圆圈图标。

十字准星工具是一种被动检查器工具。它通常始终处于开启状态,但可以在与上面显示的工具栏图标关联的检查器菜单中进行配置。

十字准星工具在绘图上绘制一个十字准星注释,该注释以当前鼠标位置为中心。通过将 dimension 属性设置为仅 widthheight,可以将十字准星工具配置为仅在一个维度上绘制。

JSON 原型
{
  "description": null, 
  "dimensions": "both", 
  "group": true, 
  "icon": null, 
  "id": "p65649", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "line_alpha": 1.0, 
  "line_color": "black", 
  "line_width": 1, 
  "name": null, 
  "overlay": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

十字准星工具要跟踪的维度。默认情况下,将绘制垂直和水平线。如果仅提供“width”,则仅绘制水平线。如果仅提供“height”,则仅绘制垂直线。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

line_alpha = 1.0#
类型:

Alpha

用于描边路径的 alpha 值。

可接受的值是介于 0 和 1 之间的浮点数(0 为透明,1 为不透明)。

line_color = 'black'#
类型:

颜色

用于描边路径的颜色。

可接受的值包括

  • 命名的 CSS 颜色,例如 'green', 'indigo' 中的任何一种

  • RGB(A) 十六进制字符串,例如 '#FF0000', '#44444444'

  • CSS4 颜色字符串,例如 'rgba(255, 0, 127, 0.6)', 'rgb(0 127 0 / 1.0)', 或 'hsl(60deg 100% 50% / 1.0)'

  • 介于 0 和 255 之间的整数的 3 元组 (r, g, b)

  • (r, g, b, a) 的 4 元组,其中 r、g、b 是介于 0 和 255 之间的整数,a 介于 0 和 1 之间

  • 使用 0xRRGGBBAA 字节顺序模式的 32 位无符号整数

line_width = 1#
类型:

浮点数

笔触宽度,单位为像素。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

overlay = 'auto'#
类型:

Either(Auto, Instance(Span), Tuple(Instance(Span), Instance(Span)))

一个用于指示十字准星的注释。

如果为 "auto",这将根据 dimensions 属性创建 span,根据其值,这将导致一个 span(水平或垂直)或两个 span(水平和垂直)。

或者,用户可以提供一个 Span 实例,其中维度由 Spandimension 属性指示。也可以提供两个 Span 实例。提供显式的 Span 实例允许构建链接的十字准星,当这些实例在不同绘图的十字准星工具之间共享时。

注意

此属性是实验性的,并且可能随时更改。特别是,将来这将允许使用除 Span 和注释组之外的其他注释。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

toggleable#

这是 ‘visible’ 属性的向后兼容别名。

注意

属性 ‘toggleable’ 在 Bokeh 3.4.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘visible’ 替代。

class CustomAction(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ActionTool

执行自定义操作,例如当工具栏图标被激活时执行 CustomJS 回调。

示例

tool = CustomAction(icon="icon.png",
                    callback=CustomJS(code='alert("foo")'))

plot.add_tools(tool)
JSON 原型
{
  "active": false, 
  "active_callback": null, 
  "callback": null, 
  "description": "Perform a Custom Action", 
  "disabled": false, 
  "group": true, 
  "icon": null, 
  "id": "p65662", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
active = False#
类型:

Bool

如果 True,则该工具当前正处于活动状态。

active_callback = None#
类型:

Nullable(Either(Instance(Callback), Auto))

一个回调函数,用于确定工具的状态。

此回调函数用于建立工具的初始状态和任何后续状态。它必须返回一个布尔值。任何其他类型的值都将被忽略。

如果使用 "auto" 值,则每次单击按钮都将切换状态。可以使用 active 属性提供初始状态。

如果使用 None 值,则该工具不是状态化的。

注意

此属性是实验性的,可能会在任何时候更改。

callback = None#
类型:

Nullable(Instance(Callback))

当自定义操作图标被激活时,要执行的 Bokeh 回调函数。

此回调函数可以返回一个布尔值,以指示工具的状态。这仅在 active_callbackNone 时适用。

description = '执行自定义操作'#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

disabled = False#
类型:

Bool

如果 True,用户将无法以任何方式与该工具交互。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *, callbacks: Callable[[Event], None] | Callable[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class CustomJSHover(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: Model

定义一个自定义格式化程序,以应用于悬停工具字段。

此模型可以使用 JavaScript 代码进行配置,以格式化悬停工具提示。JavaScript 代码可以访问要格式化的当前值、一些特殊变量以及工具提示上配置的任何格式。变量 value 将包含未转换的值。变量 special_vars 将提供一个包含以下内容的字典

  • x 鼠标在数据空间中的 x 坐标

  • y 鼠标在数据空间中的 y 坐标

  • sx 鼠标在屏幕空间中的 x 坐标

  • sy 鼠标在屏幕空间中的 y 坐标

  • data_x 悬停字形在数据空间中的 x 坐标

  • data_y 悬停字形在数据空间中的 y 坐标

  • indices 当前悬停的所有字形的列索引

  • name 悬停字形渲染器的 name 属性的值

如果悬停在 “multi” 字形(例如 PatchesMultiLine)上,则还会存在 segment_index 键。

最后,在工具提示规范中传递的格式值可以作为 format 变量使用。

示例

例如,以下代码添加了一个自定义格式化程序,用于将 WebMercator 北向坐标(以米为单位)格式化为纬度

lat_custom = CustomJSHover(code="""
    const projections = Bokeh.require("core/util/projections");
    const x = special_vars.x
    const y = special_vars.y
    const coords = projections.wgs84_mercator.invert(x, y)
    return "" + coords[1]
""")

p.add_tools(HoverTool(
    tooltips=[( 'lat','@y{custom}' )],
    formatters={'@y':lat_custom}
))

警告

此 Bokeh 模型的明确目的是嵌入原始 JavaScript 代码以供浏览器执行。如果代码的任何部分源自不受信任的用户输入,则必须采取适当的措施来清理用户输入,然后再传递给 Bokeh。

JSON 原型
{
  "args": {
    "type": "map"
  }, 
  "code": "", 
  "id": "p65674", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": []
}
args = {}#
类型:

Dict(String, AnyRef)

名称到 Bokeh 绘图对象的映射。这些对象作为回调的命名参数的值提供给回调代码段。

code = ''#
类型:

字符串

用于转换单个值的 JavaScript 代码片段。变量 value 将包含未转换的值,并且预计在渲染时存在于函数命名空间中。此外,变量 special_vars 将可用,并将提供一个包含以下内容的字典

  • x 鼠标在数据空间中的 x 坐标

  • y 鼠标在数据空间中的 y 坐标

  • sx 鼠标在屏幕空间中的 x 坐标

  • sy 鼠标在屏幕空间中的 y 坐标

  • data_x 悬停字形在数据空间中的 x 坐标

  • data_y 悬停字形在数据空间中的 y 坐标

  • indices 当前悬停的所有字形的列索引

如果悬停在 “multi” 字形(例如 PatchesMultiLine)上,则还会存在 segment_index 键。

最后,在工具提示规范中传递的格式值可以作为 format 变量使用。

该代码段将变成函数的主体,因此需要一个 return 语句。

示例

code = '''
return value + " total"
'''
name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

类方法 parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

类方法 properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

类方法 properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
属性 document: Document | None#

此模型附加到的 Document (可以是 None

class Drag(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: GestureTool

响应拖拽事件的工具的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65680", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

类方法 clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

类方法 dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

类方法 descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

类方法 from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
类方法 lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

类方法 parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class EditTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: GestureTool

所有交互式绘图工具类型的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65688", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor, Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ExamineTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ActionTool

一个允许检查和配置模型的工具。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65698", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class FreehandDrawTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类:EditToolDragTap

工具栏图标Icon of a pen drawing a wavy line representing the freehand-draw tool in the toolbar.

允许徒手绘制 PatchesMultiLine 字形。 要绘制的字形可以通过 renderers 属性定义。

该工具将修改数据源上与字形的 xsys 值对应的列。当添加新点时,数据源中的任何其他列都将使用声明的 empty_value 进行填充。

支持的操作包括

  • 绘制顶点:单击并拖动以绘制线条

  • 删除补丁/多线:点击补丁/多线以选中它,然后在鼠标位于绘图区域内时按退格键。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65706", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "num_objects": 0, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

num_objects = 0#
类型:

Int

定义可以绘制的补丁或多线的数量限制。 默认情况下,对象数量没有限制,但如果启用,则在达到限制时,最早绘制的补丁或多线将被覆盖。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class FullscreenTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ActionTool

一个允许将 UI 元素放大到全屏的工具。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65718", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class GestureTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Tool

响应拖拽事件的工具的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65726", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags =
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

类方法 descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

类方法 from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
类方法 lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

类方法 parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

类方法 properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

类方法 properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class HelpTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ActionTool

一个按钮工具,为用户提供“帮助”链接。

悬停文本可以通过 help_tooltip 属性进行自定义,重定向站点也可以被覆盖。

JSON 原型
{
  "description": "Click the question mark to learn more about Bokeh plot tools.", 
  "group": true, 
  "icon": null, 
  "id": "p65734", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "redirect": "https://docs.bokeh.org.cn/en/latest/docs/user_guide/interaction/tools.html", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = '单击问号以了解有关Bokeh绘图工具的更多信息。'#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

redirect = 'https://docs.bokeh.org.cn/en/latest/docs/user_guide/interaction/tools.html'#
类型:

字符串

单击后要重定向到的站点。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

类方法 clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class HoverTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: InspectTool

工具栏图标: 工具栏中悬停工具的弹出工具提示图标,带有表示文本抽象线条。

悬停工具是一个被动检查工具。它通常始终处于开启状态,但可以在与上面显示的工具栏图标关联的检查器菜单中进行配置。

默认情况下,当光标直接悬停在字形上方时,悬停工具会显示信息性工具提示。要显示的数据来自字形的数据源,要显示的内容可通过 tooltips 属性进行配置,该属性将显示名称映射到数据源中的列或特殊的已知变量。

以下是如何配置和使用悬停工具的示例

# Add tooltip (name, field) pairs to the tool. See below for a
# description of possible field values.
hover.tooltips = [
    ("index", "$index"),
    ("(x,y)", "($x, $y)"),
    ("radius", "@radius"),
    ("fill color", "$color[hex, swatch]:fill_color"),
    ("fill color", "$color[hex]:fill_color"),
    ("fill color", "$color:fill_color"),
    ("fill color", "$swatch:fill_color"),
    ("foo", "@foo"),
    ("bar", "@bar"),
    ("baz", "@baz{safe}"),
    ("total", "@total{$0,0.00}"),
]

您还可以为 HoverTool 提供 Callback,以构建悬停时的自定义交互。在这种情况下,您可能需要通过设置 tooltips=None 来关闭工具提示。

警告

当提供回调或自定义模板时,此 Bokeh 模型的明确意图是嵌入原始 HTML 和 JavaScript 代码,供浏览器执行。如果代码的任何部分源自不受信任的用户输入,则您必须采取适当的措施,在传递给 Bokeh 之前对用户输入进行清理。

悬停工具目前不适用于以下字形

  • annulus

  • arc

  • bezier

  • image_url

  • oval

  • patch

  • quadratic

  • ray

  • step

  • text

JSON 原型
{
  "anchor": "center", 
  "attachment": "horizontal", 
  "callback": null, 
  "description": null, 
  "formatters": {
    "type": "map"
  }, 
  "group": true, 
  "icon": null, 
  "id": "p65743", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "line_policy": "nearest", 
  "mode": "mouse", 
  "muted_policy": "show", 
  "name": null, 
  "point_policy": "snap_to_data", 
  "renderers": "auto", 
  "show_arrow": true, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "tooltips": [
    [
      "index", 
      "$index"
    ], 
    [
      "data (x, y)", 
      "($x, $y)"
    ], 
    [
      "screen (x, y)", 
      "($sx, $sy)"
    ]
  ], 
  "visible": true
}
anchor = 'center'#
类型:

Enum(Anchor)

如果点策略设置为 “snap_to_data”,则 anchor 定义工具提示的附加点。 默认设置为附加到字形的中心。

attachment = 'horizontal'#
类型:

Enum(TooltipAttachment)

工具提示应显示在光标位置的左侧或右侧,上方或下方,还是应自动放置在水平或垂直方向。

callback = None#
类型:

Nullable(Instance(Callback))

每当输入值更改时,在浏览器中运行的回调函数。cb_data 参数可用于回调代码,其中将包含两个 HoverTool 特定的字段

Index:

包含悬停点在数据源中索引的对象

Geometry:

包含悬停光标坐标的对象

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

formatters = {}#
类型:

Dict(String, Either(Enum(TooltipFieldFormatter), Instance(CustomJSHover)))

指定数据源列的格式化方案,例如:

tool.formatters = {"@date": "datetime"}

将使 “date” 列的格式规范按照 “datetime” 格式化方案进行解释。以下方案可用:

“numeral”:

为数字、货币、字节、时间和百分比提供各种格式。完整的格式集可以在 NumeralTickFormatter 参考文档中找到。

“datetime”:

为日期和时间值提供格式。完整的格式集在 DatetimeTickFormatter 参考文档中列出。

“printf”:

提供类似于 C 风格 “printf” 类型说明符的格式。有关完整详细信息,请参阅 PrintfTickFormatter 参考文档。

如果未为列名指定格式化程序,则假定默认的 "numeral" 格式化程序。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

line_policy = 'nearest'#
类型:

Enum(Enumeration(prev, next, nearest, interp, none))

指定悬停在线形图时工具提示的位置

“prev”:

在最近的两个相邻线点之间,将工具提示放置在索引较低(“previous”)的点上

“next”:

在最近的两个相邻线点之间,将工具提示放置在索引较高(“next”)的点上

“nearest”:

在最近的两个相邻线点之间,将工具提示放置在最靠近鼠标光标位置的点上

“interp”:

将工具提示放置在连接两个最近相邻线点的线段上的插值点。

“none”:

将工具提示直接放置在鼠标光标位置下方

mode = 'mouse'#
类型:

Enum(Enumeration(mouse, hline, vline))

是否将悬停指针视为点(x/y 值),还是 h 或 v 方向上的跨度。

muted_policy = 'show'#
类型:

Enum(Enumeration(show, ignore))

是否避免在静音的字形上显示工具提示。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

point_policy = 'snap_to_data'#
类型:

Enum(Enumeration(snap_to_data, follow_mouse, none))

工具提示位置应吸附到相关字形的 “中心”(或其他锚点)位置,还是始终跟随当前鼠标光标位置。

renderers = 'auto'#
类型:

Either(Auto, List)

要进行点击测试的渲染器列表。 如果未设置,则默认为绘图上的所有渲染器。

show_arrow = True#
类型:

Bool

是否应显示工具提示的箭头。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

tooltips = [('index', $index'), ('data (x, y)', '($x, $y)'), ('screen (x, y)', '($sx, $sy)')]#
类型:

Either(Null, Instance(DOMElement), String, List)

描述当发生命中时悬停工具应显示的(名称,字段)对。

以 “@” 开头的字段名称被解释为数据源中的列。例如,“@temp” 将查找要从数据源的 “temp” 列显示的值。

以 “$” 开头的字段名称是特殊的已知字段

$index:

数据源中悬停点的索引

$name:

悬停字形渲染器的 name 属性的值

$x:

数据空间中光标下的 x 坐标

$y:

数据空间中光标下的 y 坐标

$sx:

屏幕(画布)空间中光标下的 x 坐标

$sy:

屏幕(画布)空间中光标下的 y 坐标

$color:

来自数据源的颜色数据,语法为:$color[options]:field_name。可用选项为:hex(将颜色显示为十六进制值),swatch(来自数据源的颜色数据,显示为小的色块)

$swatch:

来自数据源的颜色数据,显示为小的色块

@ 开头的字段名称与 ColumnDataSource 中的列相关联。例如,字段名称 "@price" 将在每次触发悬停时显示 "price" 列的值。如果悬停针对第 17 个字形,则悬停工具提示将相应地显示第 17 个价格值。

请注意,如果列名包含空格,则必须将其括在花括号中,例如 @{adjusted close} 将显示名为 "adjusted close" 的列中的值。

有时(尤其是在堆叠图表中),希望允许间接指定列的名称。字段名称 @$name 的独特之处在于,它将在悬停的字形渲染器上查找 name 字段,并将该值用作列名。例如,如果用户悬停的名称为 "US East",则 @$name 等效于 @{US East}

默认情况下,字段的值(例如 @foo)以基本数字格式显示。但是,可以更精确地控制值的格式。可以通过在末尾的花括号中附加格式规范来修改字段。以下是一些示例。

"@foo{0,0.000}"    # formats 10000.1234 as: 10,000.123

"@foo{(.00)}"      # formats -10000.1234 as: (10000.123)

"@foo{($ 0.00 a)}" # formats 1230974 as: $ 1.23 m

在字段名称后指定格式 {safe} 将覆盖工具提示数据源的自动转义。数据标记中的任何 HTML 标记都将在生成的 HoverTool 输出中呈现为 HTML。有关更详细的示例,请参阅 自定义工具提示

None 也是工具提示的有效值。这将关闭工具提示的渲染。这在通过 callback 属性提供悬停时的其他操作时非常有用。

注意

工具提示属性也可以使用映射类型进行配置,例如 dictOrderedDict

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

具有值的属性(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

查询具有值的属性(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

引用() set[Model]#

返回此对象引用的所有 Models

移除_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

选择(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

选择一个(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

从_json_设置(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

设置选择(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

主题化的值() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

转换为可序列化(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

触发(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
移除主题() None#

删除任何主题值并恢复默认值。

返回:

None

更新(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

toggleable#

这是 ‘visible’ 属性的向后兼容别名。

注意

属性 ‘toggleable’ 在 Bokeh 3.4.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘visible’ 替代。

class InspectTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: GestureTool

用于执行“检查”的工具的基类,例如 HoverTool

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65762", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

应用主题(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod 清除扩展() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

克隆(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod 数据规格() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod 描述符() list[PropertyDescriptor]#

按定义顺序列出的属性描述符列表。

销毁() None#

清理对文档和属性的引用

等于(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod 从字符串(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor]#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod 参数() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod 属性(*, _with_props: bool = False) set[str] | dict[str, Property]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

toggleable#

这是 ‘visible’ 属性的向后兼容别名。

注意

属性 ‘toggleable’ 在 Bokeh 3.4.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘visible’ 替代。

class LassoSelectTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: Drag, RegionSelectTool

toolbar icon: Icon of a looped lasso shape representing the lasso-selection tool in the toolbar.

套索选择工具允许用户在绘图上进行选择,方法是拖动鼠标或手指在绘图区域上绘制一个自由形状的“套索”区域。拖动事件的结束表示选择区域已准备就绪。

有关样式化选定和未选定字形的信息,请参阅选定和未选定字形

注意

选择可以由多个区域组成,甚至可以是由不同的选择工具创建的区域。在进行选择时按住 SHIFT 键,可将新选择附加到可能存在的任何先前选择。

JSON 原型
{
  "continuous": true, 
  "description": null, 
  "greedy": false, 
  "group": true, 
  "icon": null, 
  "id": "p65770", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "mode": "replace", 
  "name": null, 
  "overlay": {
    "attributes": {
      "editable": true, 
      "fill_alpha": 0.5, 
      "fill_color": "lightgrey", 
      "level": "overlay", 
      "line_alpha": 1.0, 
      "line_color": "black", 
      "line_dash": [
        4, 
        4
      ], 
      "line_width": 2, 
      "syncable": false, 
      "visible": false, 
      "xs": [], 
      "ys": []
    }, 
    "id": "p65771", 
    "name": "PolyAnnotation", 
    "type": "object"
  }, 
  "persistent": false, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
continuous = True#
类型:

Bool

是否应在选择手势期间连续进行选择计算,还是仅在选择区域完成时进行一次。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

greedy = False#
类型:

Bool

定义点击字形时,是需要完全包含在选择区域内(非贪婪),还是仅需要相交(贪婪)(即,至少有一个点在区域内)。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

mode = 'replace'#
类型:

Enum(RegionSelectionMode)

定义在进行新选择时应发生什么。 默认是替换现有选择。 其他选项是追加到选择、与之相交或从中减去。

定义在进行新选择时应发生什么。

默认是替换现有选择。 其他选项是追加到选择、与之相交、从中减去或计算与它的对称差。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

overlay = PolyAnnotation(id='p65788', ...)#
类型:

Instance(PolyAnnotation)

一个阴影注释,用于指示选择区域。

persistent = False#
类型:

Bool

选择叠加层是否应在选择手势完成后保持存在。 这可以与在注释上设置 editable = True 结合使用,以允许修改选择。

renderers = 'auto'#
类型:

Either(Auto, List)

要进行点击测试的渲染器列表。 如果未设置,则默认为绘图上的所有渲染器。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[][Event], None] | Callable[][], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

select_every_mousemove#

这是 ‘continuous’ 属性的向后兼容性别名。

注意

属性 ‘select_every_mousemove’ 在 Bokeh 3.1.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘continuous’ 替代。

class LineEditTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类:EditToolDragTap

toolbar icon: Icon of a line with a point on it with an arrow pointing at it representing the line-edit tool in the toolbar.

LineEditTool 允许编辑一个或多个 Line 字形的交点。要编辑的字形通过 renderers 属性定义,而交点的渲染器通过 intersection_renderer 属性设置(必须渲染类似点的字形 (XYGlyph 的子类))。

该工具将修改数据源上与字形的 xy 值对应的列。当添加新点时,数据源中的任何其他列都将用声明的 empty_value 填充。

支持的操作包括

  • 显示交点:按下一个现有线条

  • 移动点:拖动一个现有点并松开鼠标按钮以释放它。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "dimensions": "both", 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65799", 
  "intersection_renderer": {
    "name": "unset", 
    "type": "symbol"
  }, 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

此编辑工具被约束在哪些维度中起作用。默认情况下,线条编辑工具允许在任何维度上移动点,但可以配置为仅允许在绘图宽度上水平移动,或在绘图高度上垂直移动。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

intersection_renderer = Undefined#
类型:

TypeOfAttr(Instance(GlyphRenderer))

用于渲染所选线条交点的渲染器

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class PanTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Drag

toolbar icon: 工具栏图标:代表工具栏中平移工具的四个箭头在加号形状中相遇的图标。

平移工具允许用户通过鼠标左键拖拽来平移绘图,或者在触摸设备上通过手指或触控笔在绘图区域上拖动来实现平移。

平移工具还激活了 Plot 的边框区域,用于“单轴”平移。例如,在垂直边框或轴中拖动将仅在垂直方向上产生平移效果,而水平尺寸保持固定。

JSON 原型
{
  "description": null, 
  "dimensions": "both", 
  "group": true, 
  "icon": null, 
  "id": "p65812", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

平移工具被约束作用的维度。默认情况下,平移工具将在任何维度上平移,但可以配置为仅在绘图的宽度上水平平移,或在绘图的高度上垂直平移。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class PointDrawTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类:EditToolDragTap

toolbar icon: Icon of three points with an arrow pointing to one representing the point-edit tool in the toolbar.

PointDrawTool 允许通过编辑底层 ColumnDataSource 数据,在一个或多个渲染器上添加、拖动和删除点状字形(即 XYGlyph 的子类)。与其他绘图工具一样,要编辑的渲染器必须显式地作为列表提供。任何新添加的点都将插入到第一个提供的渲染器的 ColumnDataSource 中。

该工具将修改数据源上与字形的 xy 值对应的列。当添加新点时,数据源中的任何其他列都将用给定的 empty_value 填充。

注意

数据源更新将在整个 BokehJS 端的编辑操作过程中持续触发数据更改事件。在 Bokeh 服务器应用程序中,数据源只会在编辑操作完成时同步一次。

支持的操作包括

  • 添加点:在绘图上的任意位置点击

  • 移动点:点击并拖动现有的一点,一旦松开鼠标按钮,该点将被放置在新的位置。

  • 删除点:点击一个点以选中它,然后在鼠标位于绘图区域内时按下退格键(BACKSPACE)。

JSON 原型
{
  "add": true, 
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "drag": true, 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65821", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "num_objects": 0, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
add = True#
类型:

Bool

启用在点击事件时添加新点。

default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

drag = True#
类型:

Bool

启用在平移事件时拖动现有Points。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

num_objects = 0#
类型:

Int

定义可以绘制的点数的限制。默认情况下,对象数量没有限制,但如果启用,则会删除最旧绘制的点,为新点腾出空间。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class PolyDrawTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PolyTool, Drag, Tap

toolbar icon: Icon of a solid line trapezoid with an arrow pointing at the lower right representing the polygon-draw tool in the toolbar.

PolyDrawTool 允许通过编辑底层 ColumnDataSource 数据,在一个或多个渲染器上绘制、选择和删除 PatchesMultiLine 字形。与其他绘图工具一样,要编辑的渲染器必须显式提供。

该工具将修改数据源上与字形的 xsys 值对应的列。当添加新点时,数据源中的任何其他列都将使用声明的 empty_value 进行填充。

如果提供了带有类点字形的 vertex_renderer,则 PolyDrawTool 将使用它在所有提供的渲染器上显示多线或补丁的顶点。 这也使得在绘制时能够捕捉到现有顶点。

支持的操作包括

  • 添加补丁或多线:按下以添加第一个顶点,然后使用点击添加每个后续顶点,要完成绘制操作,请按下以插入最后一个顶点或按 ESC 键。

  • 移动补丁或多线:点击并拖动现有的补丁/多线,松开鼠标按钮后,点将被放置。

  • 删除补丁或多线:点击一个补丁/多线以选中它,然后在鼠标位于绘图区域内时按下退格键。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "drag": true, 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65835", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "num_objects": 0, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "vertex_renderer": null, 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

drag = True#
类型:

Bool

在平移事件中启用拖动现有补丁和多线。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

num_objects = 0#
类型:

Int

定义可以绘制的补丁或多线的数量限制。默认情况下,对象数量没有限制,但如果启用,则会删除最旧绘制的补丁或多线,为新的补丁或多线腾出空间。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

vertex_renderer = None#
类型:

Nullable(TypeOfAttr(Instance(GlyphRenderer)))

用于渲染选定线条或多边形顶点的渲染器。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
属性 document: Document | None#

此模型附加到的 Document (可以是 None

PolyEditTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PolyTool, Drag, Tap

工具栏图标: Icon of two lines meeting in a vertex with an arrow pointing at it representing the polygon-edit tool in the toolbar.

PolyEditTool 允许编辑一个或多个 PatchesMultiLine 字形的顶点。renderers 属性定义要编辑的字形,并通过 vertex_renderer 属性设置顶点渲染器(必须渲染类似点的 Glyph(XYGlyph 的子类))。

该工具将修改数据源上与字形的 xsys 值对应的列。当添加新点时,数据源中的任何其他列都将使用声明的 empty_value 进行填充。

支持的操作包括

  • 显示顶点:按下现有的补丁或多线

  • 添加顶点:按下现有顶点以选中它,工具将绘制下一个点,要添加它,请在新位置点击。要完成编辑并添加点,请按下;否则,按 ESC 键取消。

  • 移动顶点:拖动现有顶点并松开鼠标按钮以释放它。

  • 删除顶点:选择一个或多个顶点后,当鼠标光标在绘图区域内时,按下退格键。

JSON 原型
{
  "default_overrides": {
    "type": "map"
  }, 
  "description": null, 
  "empty_value": 0, 
  "group": true, 
  "icon": null, 
  "id": "p65849", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "renderers": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "vertex_renderer": null, 
  "visible": true
}
default_overrides = {}#
类型:

Dict(String, AnyRef)

覆盖 ColumnarDataSource.default_values 的填充值。

定义在将新字形插入 ColumnDataSource 列时要插入到非坐标列中的值,例如,当圆形字形定义 "x""y""color" 列时,添加新点会将 x 和 y 坐标添加到 "x""y" 列,并且颜色列将填充定义的默认值。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

empty_value = 0#
类型:

Either(Bool, Int, Float, Date, Datetime, Color, String)

“最后手段”填充值。

当工具无法以其他方式确定默认值时,这与 default_values 的用法相同。该工具将按顺序尝试以下替代方案

  1. EditTool.default_overrides

  2. ColumnarDataSource.default_values

  3. ColumnarDataSource 的推断默认值

  4. EditTool.empty_value

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = []#
类型:

List

与可以编辑的字形相对应的渲染器列表。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

vertex_renderer = None#
类型:

Nullable(TypeOfAttr(Instance(GlyphRenderer)))

用于渲染选定线条或多边形顶点的渲染器。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

类方法 clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

类方法 dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

类方法 descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

类方法 from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
类方法 lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

类方法 parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

类方法 properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

类方法 properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class PolySelectTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基础: Tap, RegionSelectTool

工具栏图标: Icon of a dashed trapezoid with an arrow pointing at the lower right representing the polygon-selection tool in the toolbar.

多边形选择工具允许用户通过鼠标点击来指示多边形区域,从而在 Plot 上进行选择。单击(或轻敲)会将连续的点添加到多边形的定义中,而按下点击(或轻敲)则表示选择区域已准备好。

有关样式化选定和未选定字形的信息,请参阅选定和未选定字形

注意

选择可以由多个区域组成,甚至可以是由不同的选择工具创建的区域。在进行选择时按住 SHIFT 键,可将新选择附加到可能存在的任何先前选择。

JSON 原型
{
  "continuous": false, 
  "description": null, 
  "greedy": false, 
  "group": true, 
  "icon": null, 
  "id": "p65861", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "mode": "replace", 
  "name": null, 
  "overlay": {
    "attributes": {
      "editable": true, 
      "fill_alpha": 0.5, 
      "fill_color": "lightgrey", 
      "level": "overlay", 
      "line_alpha": 1.0, 
      "line_color": "black", 
      "line_dash": [
        4, 
        4
      ], 
      "line_width": 2, 
      "syncable": false, 
      "visible": false, 
      "xs": [], 
      "ys": []
    }, 
    "id": "p65862", 
    "name": "PolyAnnotation", 
    "type": "object"
  }, 
  "persistent": false, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
continuous = False#
类型:

Bool

是否应在选择手势期间连续进行选择计算,还是仅在选择区域完成时进行一次。

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

greedy = False#
类型:

Bool

定义点击字形时,是需要完全包含在选择区域内(非贪婪),还是仅需要相交(贪婪)(即,至少有一个点在区域内)。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

mode = 'replace'#
类型:

Enum(RegionSelectionMode)

定义在进行新选择时应发生什么。 默认是替换现有选择。 其他选项是追加到选择、与之相交或从中减去。

定义在进行新选择时应发生什么。

默认是替换现有选择。 其他选项是追加到选择、与之相交、从中减去或计算与它的对称差。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

overlay = PolyAnnotation(id='p65879', ...)#
类型:

Instance(PolyAnnotation)

一个阴影注释,用于指示选择区域。

persistent = False#
类型:

Bool

选择叠加层是否应在选择手势完成后保持存在。 这可以与在注释上设置 editable = True 结合使用,以允许修改选择。

renderers = 'auto'#
类型:

Either(Auto, List)

要进行点击测试的渲染器列表。 如果未设置,则默认为绘图上的所有渲染器。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

select_every_mousemove#

这是 ‘continuous’ 属性的向后兼容性别名。

注意

属性 ‘select_every_mousemove’ 在 Bokeh 3.1.0 中已被弃用,并将在未来版本中移除。请更新您的代码以使用 ‘continuous’ 替代。

class RangeTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Tool

工具栏图标: range_icon

范围工具允许用户通过拖动相应的阴影注释来移动或更改其边界,从而更新 x 或 y 维度或两者的范围对象。

一个常见的用例是将此工具添加到具有较大固定范围的绘图中,但从另一个绘图配置工具范围。当用户操作叠加层时,第二个绘图的范围将自动更新。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p65890", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "overlay": {
    "attributes": {
      "bottom": {
        "type": "number", 
        "value": "nan"
      }, 
      "bottom_limit": {
        "attributes": {
          "symbol": "bottom", 
          "target": "frame"
        }, 
        "id": "p65894", 
        "name": "Node", 
        "type": "object"
      }, 
      "editable": true, 
      "fill_alpha": 0.5, 
      "fill_color": "lightgrey", 
      "handles": {
        "attributes": {
          "all": {
            "attributes": {
              "fill_color": "white", 
              "hover_fill_color": "lightgray"
            }, 
            "id": "p65900", 
            "name": "AreaVisuals", 
            "type": "object"
          }
        }, 
        "id": "p65901", 
        "name": "BoxInteractionHandles", 
        "type": "object"
      }, 
      "left": {
        "type": "number", 
        "value": "nan"
      }, 
      "left_limit": {
        "attributes": {
          "symbol": "left", 
          "target": "frame"
        }, 
        "id": "p65891", 
        "name": "Node", 
        "type": "object"
      }, 
      "level": "overlay", 
      "line_alpha": 1.0, 
      "line_color": "black", 
      "line_dash": [
        2, 
        2
      ], 
      "line_width": 0.5, 
      "propagate_hover": true, 
      "right": {
        "type": "number", 
        "value": "nan"
      }, 
      "right_limit": {
        "attributes": {
          "symbol": "right", 
          "target": "frame"
        }, 
        "id": "p65892", 
        "name": "Node", 
        "type": "object"
      }, 
      "syncable": false, 
      "top": {
        "type": "number", 
        "value": "nan"
      }, 
      "top_limit": {
        "attributes": {
          "symbol": "top", 
          "target": "frame"
        }, 
        "id": "p65893", 
        "name": "Node", 
        "type": "object"
      }
    }, 
    "id": "p65895", 
    "name": "BoxAnnotation", 
    "type": "object"
  }, 
  "start_gesture": "none", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true, 
  "x_interaction": true, 
  "x_range": null, 
  "y_interaction": true, 
  "y_range": null
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

overlay = BoxAnnotation(id='p65966', ...)#
类型:

Instance(BoxAnnotation)

绘制阴影注释以指示配置的范围。

start_gesture = 'none'#
类型:

Enum(Enumeration(pan, tap, none))

哪种手势将在新位置启动范围更新交互。

当值为 "pan" 时,新范围在指针拖动操作开始的位置启动。范围在拖动操作继续时持续更新。结束拖动操作会设置范围的最终值。

当值为 "tap" 时,新范围在进行单次点击的位置启动。范围在指针移动时持续更新。在另一个位置点击会设置范围的最终值。

当值为 "none" 时,只能通过拖动现有范围定义的边缘或内部来更新它们。

配置此属性允许此工具与另一个原本会共享手势的工具同时共存。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

x_interaction = True#
类型:

Bool

当存在 x_range 时,是否响应水平平移运动。

默认情况下,当指定 x_range 时,可以通过在框内水平平移或沿框的顶部或底部边缘水平平移来调整范围框的水平位置。要禁用此功能并将范围框水平固定到位,请设置为 False。(如果以编程方式更新 x_range,则框仍会更新。)

x_range = None#
类型:

Nullable(Instance(Range))

与叠加层 x 维度同步的范围。如果为 None,则叠加层将跨越整个 x 维度。

y_interaction = True#
类型:

Bool

当存在 y_range 时,是否响应垂直平移运动。

默认情况下,当指定 y_range 时,可以通过在框内垂直平移或沿框的顶部或底部边缘垂直平移来调整范围框的垂直位置。要禁用此功能并将范围框垂直固定到位,请设置为 False。(如果以编程方式更新 y_range,则框仍会更新。)

y_range = None#
类型:

Nullable(Instance(Range))

与叠加层 y 维度同步的范围。如果为 None,则叠加层将跨越整个 y 维度。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[[str, Any, Any]], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class RedoTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PlotActionTool

toolbar icon: Icon of an arrow on a circular arc pointing to the right representing the redo tool in the toolbar.

重做工具反转撤销工具执行的最后一个操作。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66069", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ResetTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PlotActionTool

toolbar icon: 工具栏图标:圆形弧线上两个箭头形成一个圆圈,表示工具栏中的重置工具。

重置工具是一种操作。当在工具栏中激活时,该工具会将绘图的数据范围重置为其初始创建时的值。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66077", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

返回此对象引用的所有 Models

从此对象中删除回调

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

将此对象转换为可序列化的表示形式。

删除任何主题值并恢复默认值。

返回:

None

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)

此模型附加到的 Document (可以是 None

Bases: ActionTool

toolbar icon: Icon of a floppy disk representing the save tool in the toolbar.

保存工具是一个动作。当激活时,该工具会打开一个下载对话框,允许以 PNG 格式保存绘图的图像副本。如果 Web 浏览器不支持自动下载,则该工具会退回到在新选项卡或窗口中打开生成的图像。然后,用户可以通过右键单击图像并选择“另存为”(或类似菜单项)手动保存它。

JSON 原型
{
  "description": null, 
  "filename": null, 
  "group": true, 
  "icon": null, 
  "id": "p66085", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

filename = None#
类型:

Nullable(String)

可选字符串,用于指定已保存图像的文件名(无需扩展名)。如果未提供文件名或设置为 None,则会在保存时提示用户输入文件名。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

按定义顺序列出的属性描述符列表。

清理对文档和属性的引用

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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]"
    )
)

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class Scroll(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: GestureTool

工具类基类,用于响应滚动事件。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66094", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list:[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set:[str] | dict:[str, Property:[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict:[str, Property:[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict:[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable:[[PropertyDescriptor:[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict:[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set:[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable:[:[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable:[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type:[Model] | SelectorType, updates: dict:[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict:[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class Tap(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: GestureTool

用于响应点击/单击事件的工具的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66102", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict:[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict:[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list:[PropertyDescriptor:[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class TapTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Tap, SelectTool

工具栏图标: 工具栏中代表点击工具的两个同心圆,右下角带一个 + 号图标。

点击选择工具允许用户通过鼠标左键单击或手指点击来选择单个点。

有关样式化选定和未选定字形的信息,请参阅选定和未选定字形

注意

选择可以由多个区域组成,甚至可以是由不同的选择工具创建的区域。在进行选择时按住 SHIFT 键,可将新选择附加到可能存在的任何先前选择。

JSON 原型
{
  "behavior": "select", 
  "callback": null, 
  "description": null, 
  "gesture": "tap", 
  "group": true, 
  "icon": null, 
  "id": "p66110", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "mode": "toggle", 
  "modifiers": {
    "type": "map"
  }, 
  "name": null, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
behavior = 'select'#
类型:

Enum(Enumeration(select, inspect))

此工具可以配置为对关联的数据源进行选择或检查。区别在于选择更改会在 bokeh 中传播,并且其他组件(例如,选择字形)将收到通知。检查不会像这样操作,因此在设置 behavior='inspect' 时配置 callback 非常有用。

callback = None#
类型:

Nullable(Instance(Callback))

当字形被鼠标点击或点击“命中”时要执行的回调。

这通常与 OpenURL 模型结合使用,以根据用户单击或点击特定字形来打开 URL。

但是,它也可能是 CustomJS,它可以执行任意 JavaScript 代码以响应单击或点击字形。回调将为每个被点击或点击“命中”的单独字形执行,并将接收 TapTool 模型作为 cb_obj。可选的 cb_data 将数据源作为其 .source 属性,并将选择几何图形作为其 .geometries 属性。

.geometries 属性有 5 个成员。.type 是几何图形类型,对于点击事件始终是 .point.sx.sy 是点击发生的屏幕 X 和 Y 坐标。.x.y 是已选项目的转换后的数据坐标。.x.y 值基于分配给该字形的轴。

注意

此回调不会在每次点击时执行,仅在字形被“命中”时执行。如果您想在每次鼠标点击时执行回调,请参阅 js_on_event 回调触发器

description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

gesture = 'tap'#
类型:

Enum(Enumeration(tap, doubletap))

指定哪种手势将用于触发工具,单次点击或双击。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

mode = 'toggle'#
类型:

Enum(SelectionMode)

定义在进行新选择时应发生什么。

默认行为是切换现有选择。其他选项包括替换选择、追加选择、与选择求交集、从选择中减去或计算与选择的对称差。

modifiers = {}#
类型:

结构体

允许配置修饰键的组合,使用此工具时,需要在选定的手势期间按下这些修饰键才能触发。

例如,要仅在按下 CtrlShift 键时接受点击事件,请使用

tool = TapTool(modifiers=dict(ctrl=True, shift=True))
plot.add_tools(tool)

或者,也可以使用简洁的语法

tool = TapTool(modifiers="ctrl+shift")
plot.add_tools(tool)

警告

配置修饰键是一项依赖于平台的功能,可能会导致此工具在移动设备等平台上无法使用。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = 'auto'#
类型:

Either(Auto, List)

要进行点击测试的渲染器列表。 如果未设置,则默认为绘图上的所有渲染器。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, **callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, **, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, **callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], **callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(**, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(**, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], **, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, **callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, **, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class Tool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: Model

所有交互工具类型的基类。

注意

这是一个抽象基类,用于帮助组织 Bokeh 模型类型的层次结构。它本身实例化没有用处。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66124", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool[source]#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ToolMenu(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: Menu

工具栏以菜单或上下文菜单的形式表示。

JSON 原型
{
  "context_menu": null, 
  "css_classes": [], 
  "css_variables": {
    "type": "map"
  }, 
  "html_attributes": {
    "type": "map"
  }, 
  "html_id": null, 
  "id": "p66132", 
  "items": [], 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "reversed": false, 
  "styles": {
    "type": "map"
  }, 
  "stylesheets": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "toolbar": {
    "name": "unset", 
    "type": "symbol"
  }, 
  "visible": true
}
context_menu = None#
类型:

Nullable(Either(Instance(Menu), Enum(Enumeration(auto))))

当用户右键单击组件时显示的菜单。

如果设置为 "auto",组件可能会提供动态生成的菜单。例如,Plot 和相关模型提供了一个 ToolMenu 实例,以便轻松访问它们的工具。

注意

右键单击时使用 Shift 键以显示原生上下文菜单。

css_classes = []#
类型:

List

要添加到底层 DOM 元素的附加 CSS 类列表。

css_variables = {}#
类型:

Dict(String, Either(String, Instance(Node)))

允许定义动态计算的 CSS 变量。

例如,这可以用于协调画布的渲染器和/或视觉元素与基于 HTML 的 UI 元素之间的定位和样式。

此处定义的变量等效于在 CSS 样式表中的 :host { ... } 下设置相同的变量。

注意

此属性是实验性的,可能会在任何时候更改。

html_attributes = {}#
类型:

Dict(String, String)

允许在底层 HTML 元素上配置 HTML 属性。

html_id = None#
类型:

Nullable(String)

设置底层 HTML 元素的 id 属性。

这是常用 HTML id 属性的简写形式。或者,可以在 html_attributes 字典中设置 idhtml_id 优先。

items = []#
类型:

List

表示此菜单内容的菜单项集合。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

reversed = False#
类型:

Bool

是否保持菜单项的顺序或反转它。

styles = {}#
类型:

Either(Dict(String, Nullable(String)), Instance(Styles))

应用于底层 DOM 元素的内联 CSS 样式。

stylesheets = []#
类型:

List

用于底层 DOM 元素的附加样式表。

请注意,所有 bokeh 组件都使用 shadow DOM,因此任何包含的样式表都必须反映这一点,例如,使用 :host CSS 伪选择器来访问根 DOM 元素。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

toolbar = Undefined#
类型:

Required(Instance(Toolbar))

工具栏的引用。

visible = True#
类型:

Bool

组件是否应在屏幕上显示。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ToolProxy(*args: Any, id: ID | None = None, **kwargs: Any)[源代码]#

Bases: Model

JSON 原型
{
  "active": false, 
  "disabled": false, 
  "id": "p66147", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "tools": []
}
name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class Toolbar(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: UIElement

为单个绘图收集要显示的工具。

JSON 原型
{
  "active_drag": "auto", 
  "active_inspect": "auto", 
  "active_multi": "auto", 
  "active_scroll": "auto", 
  "active_tap": "auto", 
  "autohide": false, 
  "context_menu": null, 
  "css_classes": [], 
  "css_variables": {
    "type": "map"
  }, 
  "group": true, 
  "group_types": [
    "hover"
  ], 
  "html_attributes": {
    "type": "map"
  }, 
  "html_id": null, 
  "id": "p66151", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "logo": "normal", 
  "name": null, 
  "styles": {
    "type": "map"
  }, 
  "stylesheets": [], 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "tools": [], 
  "visible": true
}
active_drag = 'auto'#
类型:

Either(Null, Auto, Instance(Drag), Instance(ToolProxy))

指定在显示绘图时要激活的拖拽工具。

active_inspect = 'auto'#
类型:

Either(Null, Auto, Instance(InspectTool), Instance(ToolProxy), Seq(Instance(InspectTool)))

指定在显示绘图时要激活的检查工具或检查工具序列。

active_multi = 'auto'#
类型:

Either(Null, Auto, Instance(GestureTool), Instance(ToolProxy))

指定一个激活的多手势工具,例如编辑工具或范围工具。

请注意,激活多手势工具将停用任何其他适当的手势工具。例如,如果平移工具被设置为活动拖拽工具,并且此属性被设置为 BoxEditTool 实例,则平移工具将被停用(即,多手势工具将优先)。

active_scroll = 'auto'#
类型:

Either(Null, Auto, Instance(Scroll), Instance(ToolProxy))

指定在显示绘图时要激活的滚动/捏合工具。

active_tap = 'auto'#
类型:

Either(Null, Auto, Instance(Tap), Instance(ToolProxy))

指定在显示绘图时要激活的点击/单击工具。

autohide = False#
类型:

Bool

工具栏是否默认隐藏。默认值:False。如果为 True,则当光标不在画布中时隐藏工具栏。

context_menu = None#
类型:

Nullable(Either(Instance(Menu), Enum(Enumeration(auto))))

当用户右键单击组件时显示的菜单。

如果设置为 "auto",组件可能会提供动态生成的菜单。例如,Plot 和相关模型提供了一个 ToolMenu 实例,以便轻松访问它们的工具。

注意

右键单击时使用 Shift 键以显示原生上下文菜单。

css_classes = []#
类型:

List

要添加到底层 DOM 元素的附加 CSS 类列表。

css_variables = {}#
类型:

Dict(String, Either(String, Instance(Node)))

允许定义动态计算的 CSS 变量。

例如,这可以用于协调画布的渲染器和/或视觉元素与基于 HTML 的 UI 元素之间的定位和样式。

此处定义的变量等效于在 CSS 样式表中的 :host { ... } 下设置相同的变量。

注意

此属性是实验性的,可能会在任何时候更改。

group = True#
类型:

Bool

是否对常用工具进行分组。

group_types = ['hover']#
类型:

List

仅对给定类型的工具进行分组。

html_attributes = {}#
类型:

Dict(String, String)

允许在底层 HTML 元素上配置 HTML 属性。

html_id = None#
类型:

Nullable(String)

设置底层 HTML 元素的 id 属性。

这是常用 HTML id 属性的简写形式。或者,可以在 html_attributes 字典中设置 idhtml_id 优先。

类型:

Nullable(Enum(Enumeration(normal, grey)))

要在工具栏上显示的 Bokeh 标志的版本。如果设置为 None,则不显示任何标志。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

styles = {}#
类型:

Either(Dict(String, Nullable(String)), Instance(Styles))

应用于底层 DOM 元素的内联 CSS 样式。

stylesheets = []#
类型:

List

用于底层 DOM 元素的附加样式表。

请注意,所有 bokeh 组件都使用 shadow DOM,因此任何包含的样式表都必须反映这一点,例如,使用 :host CSS 伪选择器来访问根 DOM 元素。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

tools = []#
类型:

List

要添加到绘图的工具列表。

visible = True#
类型:

Bool

组件是否应在屏幕上显示。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class UndoTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: PlotActionTool

toolbar icon: Icon of an arrow on a circular arc pointing to the left representing the undo tool in the toolbar.

撤销工具允许恢复绘图的先前状态。

JSON 原型
{
  "description": null, 
  "group": true, 
  "icon": null, 
  "id": "p66173", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class WheelPanTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Scroll

工具栏图标: Icon of a mouse shape next to crossed arrows representing the wheel-pan tool in the toolbar.

滚轮平移工具允许用户使用滚轮沿配置的维度平移绘图。

JSON 原型
{
  "description": null, 
  "dimension": "width", 
  "group": true, 
  "icon": null, 
  "id": "p66181", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "modifiers": {
    "type": "map"
  }, 
  "name": null, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimension = 'width'#
类型:

Enum(Dimension)

滚轮平移工具被限制在哪个维度上操作。 默认情况下,滚轮平移工具将沿 x 轴平移绘图。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

modifiers = {}#
类型:

结构体

允许配置修饰键的组合,使用此工具时,需要在选定的手势期间按下这些修饰键才能触发。

例如,要仅在按下 CtrlShift 键时进行平移,请使用

tool = WheelPanTool(modifiers=dict(ctrl=True, shift=True))
plot.add_tools(tool)

或者,也可以使用简洁的语法

tool = WheelPanTool(modifiers="ctrl+shift")
plot.add_tools(tool)

注意

如果 Toolbar.active_scroll 设置为 "auto",则设置 modifiers 允许自动激活此工具。

警告

配置修饰键是一项依赖于平台的功能,可能会导致此工具在移动设备等平台上无法使用。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class WheelZoomTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

基类: Scroll

toolbar icon: Icon of a mouse shape next to an hourglass representing the wheel-zoom tool in the toolbar.

滚轮缩放工具将**在当前鼠标位置为中心**放大和缩小绘图。

滚轮缩放工具还会激活 Plot 的边框区域,以进行“单轴”缩放。例如,在垂直边框或轴上缩放将仅影响垂直方向的缩放,而水平维度保持固定。

JSON 原型
{
  "description": null, 
  "dimensions": "both", 
  "group": true, 
  "hit_test": false, 
  "hit_test_behavior": "only_hit", 
  "hit_test_mode": "point", 
  "icon": null, 
  "id": "p66191", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "level": 0, 
  "maintain_focus": true, 
  "modifiers": {
    "type": "map"
  }, 
  "name": null, 
  "renderers": "auto", 
  "speed": 0.0016666666666666668, 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true, 
  "zoom_on_axis": true, 
  "zoom_together": "all"
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

滚轮缩放工具被约束作用的维度。默认情况下,滚轮缩放工具将在任何维度上缩放,但可以配置为仅在绘图的宽度上水平缩放,或在绘图的高度上垂直缩放。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

hit_test = False#
类型:

Bool

是否仅缩放那些被指向的渲染器。

此设置仅在缩放配置了子坐标的渲染器时适用,否则无效。

如果 True,则 hit_test_mode 属性定义如何执行命中测试,并且 hit_test_behavior 允许配置此设置的其他方面。 有关详细信息,请参阅各个属性。

注意

此属性是实验性的,可能随时更改

hit_test_behavior = 'only_hit'#
类型:

Either(Instance(GroupBy), Enum(Enumeration(only_hit)))

允许配置当 hit_test 启用时,哪些渲染器将被缩放。

默认情况下 (hit_only) 仅实际命中的渲染器将被缩放。 GroupBy 模型的实例可用于告知当给定渲染器被命中时,还应缩放哪些其他渲染器。

注意

此属性是实验性的,可能随时更改

hit_test_mode = 'point'#
类型:

Enum(Enumeration(point, hline, vline))

允许配置当 hit_test 启用时,要使用什么几何图形。

支持的模式有 "point" 用于单点命中测试,以及 hlinevline 用于水平或垂直跨度命中测试。

注意

此属性是实验性的,可能随时更改

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

level = 0#
类型:

NonNegative

当使用复合比例(子坐标)时,此属性允许配置要缩放的范围集。 默认值是缩放顶层(框架)范围。

maintain_focus = True#
类型:

Bool

如果为 True,则在任何一个维度中命中范围边界将阻止所有进一步的所有维度缩放。 如果为 False,则即使导致整体焦点或纵横比发生变化,缩放也可以在尚未达到其边界的任何维度中独立继续。

modifiers = {}#
类型:

结构体

允许配置修饰键的组合,使用此工具时,需要在选定的手势期间按下这些修饰键才能触发。

例如,要仅在按下 CtrlShift 键时进行缩放,请使用

tool = WheelZoomTool(modifiers=dict(ctrl=True, shift=True))
plot.add_tools(tool)

或者,也可以使用简洁的语法

tool = WheelZoomTool(modifiers="ctrl+shift")
plot.add_tools(tool)

注意

如果 Toolbar.active_scroll 设置为 "auto",则设置 modifiers 允许自动激活此工具。

警告

配置修饰键是一项依赖于平台的功能,可能会导致此工具在移动设备等平台上无法使用。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = 'auto'#
类型:

Either(Auto, List)

将缩放限制为提供的 data renderer 使用的范围。 如果为 "auto",则将使用笛卡尔框架提供的所有范围。

speed = 0.0016666666666666668#
类型:

浮点数

滚轮缩放的速度。 默认值为 1/600。 最佳范围介于 0.001 和 0.09 之间。 高值将被裁剪。 速度可能因浏览器而异。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

zoom_on_axis = True#
类型:

Bool

是否应在轴上滚动(在中心绘图区域之外)来缩放该维度。 如果启用,则可以使用 zoom_together 属性配置此功能的行为。

zoom_together = 'all'#
类型:

Enum(Enumeration(none, cross, all))

定义在轴上缩放时工具的行为

  • "none"

    仅缩放正在与之交互的轴。 此轴维度中的任何交叉轴或任何其他轴都不会受到影响。

  • "cross"

    缩放正在与之交互的轴及其交叉轴(如果已配置)。 此维度或交叉维度中的任何其他轴都不会受到影响。

  • "all"

    缩放正在与之交互的轴的维度中的所有轴。 所有交叉轴都不会受到影响。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property]Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property]Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor]Any], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None

class ZoomInTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ZoomBaseTool

toolbar icon: 工具栏中表示放大工具的加号和放大镜图标

放大工具允许用户单击按钮以固定量放大。

JSON 原型
{
  "description": null, 
  "dimensions": "both", 
  "factor": 0.1, 
  "group": true, 
  "icon": null, 
  "id": "p66210", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "level": 0, 
  "name": null, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

缩放工具被限制在哪些维度中起作用。 默认情况下,该工具将在任何维度上放大,但可以配置为仅在绘图的宽度上水平缩放,或在绘图的高度上垂直缩放。

factor = 0.1#
类型:

百分比

每次使用该工具时要缩放的范围百分比。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

level = 0#
类型:

NonNegative

当使用复合比例(子坐标)时,此属性允许配置要缩放的范围集。 默认值是缩放顶层(框架)范围。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = 'auto'#
类型:

Either(Auto, List)

将缩放限制为提供的 data renderer 使用的范围。 如果为 "auto",则将使用笛卡尔框架提供的所有范围。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

classmethod clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

classmethod dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

classmethod descriptors() list[PropertyDescriptor]Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

classmethod from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
类方法 lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

类方法 parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

类方法 properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

类方法 properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
属性 document: Document | None#

此模型附加到的 Document (可以是 None

ZoomOutTool(*args: Any, id: ID | None = None, **kwargs: Any)[source]#

Bases: ZoomBaseTool

工具栏图标: Icon of a minus sign next to a magnifying glass representing the zoom-out tool in the toolbar.

缩小工具允许用户点击按钮以缩小固定量。

JSON 原型
{
  "description": null, 
  "dimensions": "both", 
  "factor": 0.1, 
  "group": true, 
  "icon": null, 
  "id": "p66222", 
  "js_event_callbacks": {
    "type": "map"
  }, 
  "js_property_callbacks": {
    "type": "map"
  }, 
  "level": 0, 
  "maintain_focus": true, 
  "name": null, 
  "renderers": "auto", 
  "subscribed_events": {
    "type": "set"
  }, 
  "syncable": true, 
  "tags": [], 
  "visible": true
}
description = None#
类型:

Nullable(String)

描述此工具用途的字符串。如果未定义,将使用自动生成的描述。此描述通常会在用户界面中显示为工具提示。

dimensions = 'both'#
类型:

Enum(Dimensions)

缩放工具被限制在哪些维度中起作用。 默认情况下,该工具将在任何维度上放大,但可以配置为仅在绘图的宽度上水平缩放,或在绘图的高度上垂直缩放。

factor = 0.1#
类型:

百分比

每次使用该工具时要缩放的范围百分比。

group = True#
类型:

Either(String, Bool)

此工具所属组的名称。

默认设置为 True,表示默认组。如果设置为 False,它将阻止该工具被分组(无论 Toolbar.group 设置如何)。

icon = None#
类型:

Nullable(Either(Image, Enum(ToolIcon), Regex, Regex, Regex))

要在工具栏中显示的图标。

图标可以作为众所周知的工具图标名称、CSS 类选择器、带有 image/* MIME 的数据 URI、图像路径、PIL Image 对象或 RGB(A) NumPy 数组提供。如果为 None,则将使用固有图标(可能取决于工具的配置)。

level = 0#
类型:

NonNegative

当使用复合比例(子坐标)时,此属性允许配置要缩放的范围集。 默认值是缩放顶层(框架)范围。

maintain_focus = True#
类型:

Bool

如果为 True,则在任何一个维度中达到范围边界将阻止所有维度中进一步的缩放。如果为 False,则缩放可以在尚未达到其边界的任何维度中独立继续,即使这会导致整体焦点或纵横比发生变化。

name = None#
类型:

Nullable(String)

此模型的任意、用户提供的名称。

在查询文档以检索特定的 Bokeh 模型时,此名称可能很有用。

>>> plot.scatter([1,2,3], [4,5,6], name="temp")
>>> plot.select(name="temp")
[GlyphRenderer(id='399d53f5-73e9-44d9-9527-544b761c7705', ...)]

注意

对于提供的任何名称,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用该名称。

renderers = 'auto'#
类型:

Either(Auto, List)

将缩放限制为提供的 data renderer 使用的范围。 如果为 "auto",则将使用笛卡尔框架提供的所有范围。

syncable = True#
类型:

Bool

指示此模型在 Web 浏览器中更新时是否应同步回 Bokeh 服务器。当处理频繁更新的对象,而我们不需要其更新值时,设置为 False 可能有助于减少网络流量。

注意

将此属性设置为 False 将阻止此对象上的任何 on_change() 回调触发。但是,任何 JS 端回调仍然有效。

tags = []#
类型:

List

要附加到此模型的可选的、用户提供的任意值列表。

当查询文档以检索特定的 Bokeh 模型时,此数据可能很有用

>>> r = plot.scatter([1,2,3], [4,5,6])
>>> r.tags = ["foo", 10]
>>> plot.select(tags=['foo', 10])
[GlyphRenderer(id='1de4c3df-a83d-480a-899b-fb263d3d5dd9', ...)]

或者只是将任何必要的元数据附加到可通过 CustomJS 回调等访问的模型的便捷方法。

注意

对于提供的任何标签,不强制执行唯一性保证或其他条件,Bokeh 也不会出于任何原因直接使用标签。

visible = True#
类型:

Bool

与此工具关联的工具按钮是否应显示在工具栏中。

apply_theme(property_values: dict[str, Any]) None#

应用一组主题值,这些值将代替默认值使用,但不会覆盖应用程序设置的值。

传入的字典可以按原样保留并与其他实例共享,以节省内存(因此调用者和 HasProps 实例都不应修改它)。

参数:

property_values (dict) – 用于代替默认值的主题值

返回:

None

类方法 clear_extensions() None#

清除当前定义的任何自定义扩展。

序列化调用将导致任何当前定义的自定义扩展包含在生成的文档中,无论是否使用它们。此方法可用于清除所有现有的自定义扩展定义。

clone(**overrides: Any) Self#

复制 HasProps 对象。

这将创建原始模型的浅层克隆,即,任何可变容器或子模型都不会被复制。允许在克隆时覆盖特定属性。

类方法 dataspecs() dict[str, DataSpec]#

收集此类上所有 DataSpec 属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

DataSpec 属性的名称

返回类型:

set[str]

类方法 descriptors() list[PropertyDescriptor[Any]]#

按定义顺序列出的属性描述符列表。

destroy() None#

清理对文档和属性的引用

equals(other: HasProps) bool#

模型的结构相等性。

参数:

other (HasProps) – 要比较的另一个实例

返回:

如果属性在结构上相等,则为 True,否则为 False

类方法 from_string(name: str) Tool#

接受一个字符串并返回相应的 Tool 实例。

使用 JavaScript 链接两个 Bokeh 模型属性。

这是一种便捷方法,可简化添加 CustomJS 回调,以便在一个 Bokeh 模型属性的值更改时更新另一个属性。

参数:
  • attr (str) – 此模型上 Bokeh 属性的名称

  • other (Model) – 要链接到 self.attr 的 Bokeh 模型

  • other_attr (str) – 要链接在一起的 other 上的属性

  • attr_selector (int | str) – 用于链接可下标 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"
    )
)

此外,要使用 attr_selector 将范围滑块的左侧附加到绘图的 x_range

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(event: str, *callbacks: JSChangeCallback) None#

CustomJS 回调附加到任意 BokehJS 模型事件。

在 BokehJS 端,模型属性的更改事件的形式为 "change:property_name"。为了方便起见,如果传递给此方法的事件名称也是模型上属性的名称,则会自动在其前面加上 "change:"

# these two are equivalent
source.js_on_change('data', callback)
source.js_on_change('change:data', callback)

但是,除了属性更改事件之外,还有其他类型的事件可能需要响应。例如,要每当数据流式传输到 ColumnDataSource 时运行回调,请使用源上的 "stream" 事件

source.js_on_change('streaming', callback)
classmethod lookup(name: str, *, raises: bool = True) PropertyDescriptor[Any] | None#

查找类上 Bokeh 属性的 PropertyDescriptor,给定属性名称。

参数:
  • name (str) – 要搜索的属性的名称

  • raises (bool) – 如果缺少,是否引发异常或返回 None

返回:

名为 name 的属性的描述符

返回类型:

PropertyDescriptor

on_change(attr: str, *callbacks: PropertyCallback) None#

在此对象上添加一个回调,以便在 attr 更改时触发。

参数:
  • attr (str) – 此对象上的属性名称

  • *callbacks (callable) – 要注册的回调函数

返回:

None

示例

widget.on_change('value', callback1, callback2, ..., callback_n)
on_event(event: str | type[Event], *callbacks: Callable[[Event], None] | Callable[[], None]) None#

当此模型上发生指定的事件时运行回调

并非所有模型都支持所有事件。有关哪些模型能够触发事件的更多信息,请参阅 bokeh.events 中的特定事件。

classmethod parameters() list[Parameter]#

生成适用于从字形派生的函数的 Python Parameter 值。

返回:

list(Parameter)

classmethod properties(*, _with_props: bool = False) set[str] | dict[str, Property[Any]]#

收集此类上的属性名称。

警告

在未来版本的 Bokeh 中,此方法将返回一个字典,该字典将属性名称映射到属性对象。为了使当前对此方法的使用在未来仍然有效,请将返回值包装在 list 中。

返回:

属性名称

classmethod properties_with_refs() dict[str, Property[Any]]#

收集此类上所有也具有引用的属性的名称。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

返回:

具有引用的属性的名称

返回类型:

set[str]

properties_with_values(*, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

收集一个字典,该字典将属性名称映射到它们的值。

此方法始终遍历类层次结构,并包括在任何父类上定义的属性。

不可序列化的属性将被跳过,并且属性值采用“序列化”格式,这可能与您通常从属性中读取的值略有不同;此方法的目的是返回无损地重建对象实例所需的信息。

参数:

include_defaults (bool, 可选) – 是否包括自对象创建以来尚未显式设置的属性。(默认值:True)

返回:

从属性名称到其值的映射

返回类型:

字典

query_properties_with_values(query: Callable[[PropertyDescriptor[Any]], bool], *, include_defaults: bool = True, include_undefined: bool = False) dict[str, Any]#

使用谓词查询 HasProps 实例的属性值。

参数:
  • query (callable) – 接受属性描述符并返回 True 或 False 的可调用对象

  • include_defaults (bool, 可选) – 是否包括用户尚未显式设置的属性(默认值:True)

返回:

匹配属性的属性名称和值的映射

返回类型:

字典

references() set[Model]#

返回此对象引用的所有 Models

remove_on_change(attr: str, *callbacks: Callable[[str, Any, Any], None]) None#

从此对象中删除回调

select(selector: SelectorType) Iterable[Model]#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。

参数:

selector (JSON-like)

返回:

seq[Model]

select_one(selector: SelectorType) Model | None#

查询此对象及其所有引用,以查找与给定选择器匹配的对象。如果找到多个对象,则引发错误。返回单个匹配对象,如果未找到任何对象,则返回 None :param selector: :type selector: JSON-like

返回:

模型

set_from_json(name: str, value: Any, *, setter: Setter | None = None) None#

从此对象的 JSON 中设置属性值。

参数:
  • name (str) – 要设置的属性的名称

  • value (JSON-value) – 要设置为属性的值

  • setter (ClientSessionServerSessionNone, 可选) –

    这用于防止对 Bokeh 应用程序的“回旋镖”更新。

    在 Bokeh 服务器应用程序的上下文中,传入的属性更新将使用正在执行更新的会话进行注释。此值会通过更新触发的任何后续更改通知进行传播。会话可以将事件 setter 与自身进行比较,并抑制任何源自自身的更新。

返回:

None

set_select(selector: type[Model] | SelectorType, updates: dict[str, Any]) None#

使用指定的属性/值更新来更新与给定选择器匹配的对象。

参数:
  • selector (JSON-like)

  • updates (dict)

返回:

None

themed_values() dict[str, Any] | None#

获取任何主题提供的覆盖。

结果以从属性名称到值的字典形式返回,如果此实例没有任何主题覆盖任何值,则返回 None

返回:

字典或 None

to_serializable(serializer: Serializer) ObjectRefRep#

将此对象转换为可序列化的表示形式。

trigger(attr: str, old: Any, new: Any, hint: DocumentPatchedEvent | None = None, setter: Setter | None = None) None#
unapply_theme() None#

删除任何主题值并恢复默认值。

返回:

None

update(**kwargs: Any) None#

从给定的关键字参数更新对象的属性。

返回:

None

示例

以下是等效的

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)
property document: Document | None#

此模型附加到的 Document (可以是 None