AsyncCallbackManagerForChainGroup#

class langchain_core.callbacks.manager.AsyncCallbackManagerForChainGroup(handlers: list[BaseCallbackHandler], inheritable_handlers: list[BaseCallbackHandler] | None = None, parent_run_id: UUID | None = None, *, parent_run_manager: AsyncCallbackManagerForChainRun, **kwargs: Any)[source]#

链组的异步回调管理器。

初始化异步回调管理器。

Parameters:
  • handlers (List[BaseCallbackHandler]) – 处理程序列表。

  • inheritable_handlers (Optional[List[BaseCallbackHandler]]) – 可继承的处理程序列表。默认为 None。

  • parent_run_id (可选[UUID]) – 父运行的ID。默认为None。

  • parent_run_manager (AsyncCallbackManagerForChainRun) – 父运行管理器。

  • **kwargs (Any) – 额外的关键字参数。

属性

is_async

返回处理程序是否为异步。

方法

__init__(handlers[, inheritable_handlers, ...])

初始化异步回调管理器。

add_handler(handler[, inherit])

向回调管理器添加一个处理程序。

add_metadata(metadata[, inherit])

向回调管理器添加元数据。

add_tags(tags[, inherit])

向回调管理器添加标签。

configure([inheritable_callbacks, ...])

配置异步回调管理器。

copy()

复制异步回调管理器。

merge(other)

将组回调管理器与另一个回调管理器合并。

on_chain_end(outputs, **kwargs)

当跟踪的链组结束时运行。

on_chain_error(error, **kwargs)

当链发生错误时运行。

on_chain_start(serialized, inputs[, run_id])

当链开始运行时异步执行。

on_chat_model_start(serialized, messages[, ...])

当LLM开始运行时异步执行。

on_custom_event(name, data[, run_id])

将临时事件分派给处理程序(异步版本)。

on_llm_start(serialized, prompts[, run_id])

当LLM开始运行时执行。

on_retriever_start(serialized, query[, ...])

当检索器开始运行时执行。

on_tool_start(serialized, input_str[, ...])

当工具开始运行时执行。

remove_handler(handler)

从回调管理器中移除一个处理程序。

remove_metadata(keys)

从回调管理器中移除元数据。

remove_tags(tags)

从回调管理器中移除标签。

set_handler(handler[, inherit])

将处理程序设置为回调管理器上的唯一处理程序。

set_handlers(handlers[, inherit])

将处理程序设置为回调管理器上的唯一处理程序。

__init__(handlers: list[BaseCallbackHandler], inheritable_handlers: list[BaseCallbackHandler] | None = None, parent_run_id: UUID | None = None, *, parent_run_manager: AsyncCallbackManagerForChainRun, **kwargs: Any) None[源代码]#

初始化异步回调管理器。

Parameters:
  • handlers (List[BaseCallbackHandler]) – 处理程序列表。

  • inheritable_handlers (Optional[List[BaseCallbackHandler]]) – 可继承的处理程序列表。默认为 None。

  • parent_run_id (可选[UUID]) – 父运行的ID。默认为None。

  • parent_run_manager (AsyncCallbackManagerForChainRun) – 父运行管理器。

  • **kwargs (Any) – 额外的关键字参数。

Return type:

add_handler(handler: BaseCallbackHandler, inherit: bool = True) None#

向回调管理器添加一个处理程序。

Parameters:
  • handler (BaseCallbackHandler) – 要添加的处理程序。

  • inherit (bool) – 是否继承处理程序。默认为 True。

Return type:

add_metadata(metadata: dict[str, Any], inherit: bool = True) None#

向回调管理器添加元数据。

Parameters:
  • metadata (Dict[str, Any]) – 要添加的元数据。

  • inherit (bool) – 是否继承元数据。默认值为 True。

Return type:

add_tags(tags: list[str], inherit: bool = True) None#

向回调管理器添加标签。

Parameters:
  • tags (List[str]) – 要添加的标签。

  • inherit (bool) – 是否继承标签。默认值为 True。

Return type:

classmethod configure(inheritable_callbacks: list[BaseCallbackHandler] | BaseCallbackManager | None = None, local_callbacks: list[BaseCallbackHandler] | BaseCallbackManager | None = None, verbose: bool = False, inheritable_tags: list[str] | None = None, local_tags: list[str] | None = None, inheritable_metadata: dict[str, Any] | None = None, local_metadata: dict[str, Any] | None = None) AsyncCallbackManager#

配置异步回调管理器。

Parameters:
  • inheritable_callbacks (Optional[Callbacks], optional) – 可继承的回调函数。默认为 None。

  • local_callbacks (Optional[Callbacks], optional) – 本地回调函数。 默认值为 None。

  • verbose (bool, optional) – 是否启用详细模式。默认为 False。

  • inheritable_tags (Optional[List[str]], optional) – 可继承的标签。 默认为 None。

  • local_tags (可选[列表[字符串]], 可选) – 本地标签。 默认为 None。

  • inheritable_metadata (Optional[Dict[str, Any]], optional) – 可继承的元数据。默认为 None。

  • local_metadata (Optional[Dict[str, Any]], optional) – 本地元数据。 默认为 None。

Returns:

配置的异步回调管理器。

Return type:

AsyncCallbackManager

copy() AsyncCallbackManagerForChainGroup[source]#

复制异步回调管理器。

Return type:

AsyncCallbackManagerForChainGroup

merge(other: BaseCallbackManager) AsyncCallbackManagerForChainGroup[source]#

将组回调管理器与另一个回调管理器合并。

重写基类中的合并方法,以确保保留父运行管理器。从当前对象中保留父运行管理器。

Returns:

当前AsyncCallbackManagerForChainGroup的副本

合并了其他回调管理器的处理程序、标签等。

Return type:

AsyncCallbackManagerForChainGroup

Parameters:

示例:合并两个回调管理器。

from langchain_core.callbacks.manager import CallbackManager, atrace_as_chain_group
from langchain_core.callbacks.stdout import StdOutCallbackHandler

manager = CallbackManager(handlers=[StdOutCallbackHandler()], tags=["tag2"])
async with atrace_as_chain_group("My Group Name", tags=["tag1"]) as group_manager:
    merged_manager = group_manager.merge(manager)
    print(type(merged_manager))
    # <class 'langchain_core.callbacks.manager.AsyncCallbackManagerForChainGroup'>

    print(merged_manager.handlers)
    # [
    #    <langchain_core.callbacks.stdout.LangChainTracer object at ...>,
    #    <langchain_core.callbacks.streaming_stdout.StdOutCallbackHandler object at ...>,
    # ]

    print(merged_manager.tags)
    #    ['tag2', 'tag1']
async on_chain_end(outputs: dict[str, Any] | Any, **kwargs: Any) None[source]#

当跟踪的链组结束时运行。

Parameters:
  • outputs (Union[Dict[str, Any], Any]) – 链的输出。

  • **kwargs (Any) – 额外的关键字参数。

Return type:

async on_chain_error(error: BaseException, **kwargs: Any) None[source]#

当链发生错误时运行。

Parameters:
  • error (ExceptionKeyboardInterrupt) – 错误。

  • **kwargs (Any) – 额外的关键字参数。

Return type:

async on_chain_start(serialized: dict[str, Any] | None, inputs: dict[str, Any] | Any, run_id: UUID | None = None, **kwargs: Any) AsyncCallbackManagerForChainRun#

当链开始运行时异步运行。

Parameters:
  • serialized (可选[字典[字符串, 任意类型]]) – 序列化的链。

  • inputs (Union[Dict[str, Any], Any]) – 链的输入。

  • run_id (UUID, optional) – 运行的ID。默认为None。

  • **kwargs (Any) – 额外的关键字参数。

Returns:

异步回调管理器

用于链式运行。

Return type:

AsyncCallbackManagerForChainRun

async on_chat_model_start(serialized: dict[str, Any], messages: list[list[BaseMessage]], run_id: UUID | None = None, **kwargs: Any) list[AsyncCallbackManagerForLLMRun]#

当LLM开始运行时异步运行。

Parameters:
  • serialized (Dict[str, Any]) – 序列化的LLM。

  • messages (List[List[BaseMessage]]) – 消息列表。

  • run_id (UUID, optional) – 运行的ID。默认为None。

  • **kwargs (Any) – 额外的关键字参数。

Returns:

列表

异步回调管理器,每个LLM运行对应一个内部消息列表。

Return type:

列表[AsyncCallbackManagerForLLMRun]

async on_custom_event(name: str, data: Any, run_id: UUID | None = None, **kwargs: Any) None#

向处理程序分派一个临时事件(异步版本)。

此事件不应在任何内部LangChain代码中使用。该事件专门为库的用户设计,用于分派适合其应用程序的自定义事件。

Parameters:
  • name (str) – 临时事件的名称。

  • data (Any) – 临时事件的数据。

  • run_id (UUID | None) – 运行的ID。默认为None。

  • kwargs (Any)

Return type:

在版本0.2.14中添加。

async on_llm_start(serialized: dict[str, Any], prompts: list[str], run_id: UUID | None = None, **kwargs: Any) list[AsyncCallbackManagerForLLMRun]#

当LLM开始运行时执行。

Parameters:
  • serialized (Dict[str, Any]) – 序列化的LLM。

  • prompts (List[str]) – 提示列表。

  • run_id (UUID, optional) – 运行的ID。默认为None。

  • **kwargs (Any) – 额外的关键字参数。

Returns:

异步列表

回调管理器,每个LLM运行对应一个提示。

Return type:

列表[AsyncCallbackManagerForLLMRun]

async on_retriever_start(serialized: dict[str, Any] | None, query: str, run_id: UUID | None = None, parent_run_id: UUID | None = None, **kwargs: Any) AsyncCallbackManagerForRetrieverRun#

当检索器开始运行时运行。

Parameters:
  • serialized (可选[字典[字符串, 任意类型]]) – 序列化的检索器。

  • query (str) – 查询。

  • run_id (UUID, optional) – 运行的ID。默认为None。

  • parent_run_id (UUID, optional) – 父运行的ID。默认为None。

  • **kwargs (Any) – 额外的关键字参数。

Returns:

异步回调管理器

用于检索器运行。

Return type:

AsyncCallbackManagerForRetrieverRun

async on_tool_start(serialized: dict[str, Any] | None, input_str: str, run_id: UUID | None = None, parent_run_id: UUID | None = None, **kwargs: Any) AsyncCallbackManagerForToolRun#

当工具开始运行时执行。

Parameters:
  • serialized (可选[Dict[str, Any]]) – 序列化的工具。

  • input_str (str) – 工具的输入。

  • run_id (UUID, optional) – 运行的ID。默认为None。

  • parent_run_id (UUID, optional) – 父运行的ID。默认为None。

  • **kwargs (Any) – 额外的关键字参数。

Returns:

异步回调管理器

用于工具运行。

Return type:

AsyncCallbackManagerForToolRun

remove_handler(handler: BaseCallbackHandler) None#

从回调管理器中移除一个处理程序。

Parameters:

handler (BaseCallbackHandler) – 要移除的处理程序。

Return type:

remove_metadata(keys: list[str]) None#

从回调管理器中移除元数据。

Parameters:

keys (List[str]) – 要移除的键。

Return type:

remove_tags(tags: list[str]) None#

从回调管理器中移除标签。

Parameters:

标签 (列表[字符串]) – 要移除的标签。

Return type:

set_handler(handler: BaseCallbackHandler, inherit: bool = True) None#

将处理程序设置为回调管理器上的唯一处理程序。

Parameters:
  • handler (BaseCallbackHandler) – 要设置的处理器。

  • inherit (bool) – 是否继承处理程序。默认为 True。

Return type:

set_handlers(handlers: list[BaseCallbackHandler], inherit: bool = True) None#

将处理程序设置为回调管理器上的唯一处理程序。

Parameters:
  • handlers (List[BaseCallbackHandler]) – 要设置的处理器。

  • inherit (bool) – 是否继承处理程序。默认值为 True。

Return type: