Source code for langchain_core.outputs.chat_generation

from __future__ import annotations

from typing import Any, Dict, List, Literal

from langchain_core.messages import BaseMessage, BaseMessageChunk
from langchain_core.outputs.generation import Generation
from langchain_core.pydantic_v1 import root_validator
from langchain_core.utils._merge import merge_dicts


[docs]class ChatGeneration(Generation): """单个聊天生成输出。""" text: str = "" """*不应直接设置* 输出消息的文本内容。""" message: BaseMessage """聊天模型输出的消息。""" # Override type to be ChatGeneration, ignore mypy error as this is intentional type: Literal["ChatGeneration"] = "ChatGeneration" # type: ignore[assignment] """Type 仅用于序列化目的。""" @root_validator def set_text(cls, values: Dict[str, Any]) -> Dict[str, Any]: """将文本属性设置为消息的内容。""" try: text = "" if isinstance(values["message"].content, str): text = values["message"].content # HACK: Assumes text in content blocks in OpenAI format. # Uses first text block. elif isinstance(values["message"].content, list): for block in values["message"].content: if isinstance(block, str): text = block break elif isinstance(block, dict) and "text" in block: text = block["text"] break else: pass else: pass values["text"] = text except (KeyError, AttributeError) as e: raise ValueError("Error while initializing ChatGeneration") from e return values
[docs] @classmethod def get_lc_namespace(cls) -> List[str]: """获取langchain对象的命名空间。""" return ["langchain", "schema", "output"]
[docs]class ChatGenerationChunk(ChatGeneration): """聊天生成块,可以与其他聊天生成块连接。 属性: message: 聊天模型输出的消息块。""" message: BaseMessageChunk # Override type to be ChatGeneration, ignore mypy error as this is intentional type: Literal["ChatGenerationChunk"] = "ChatGenerationChunk" # type: ignore[assignment] # noqa: E501 """Type 仅用于序列化目的。"""
[docs] @classmethod def get_lc_namespace(cls) -> List[str]: """获取langchain对象的命名空间。""" return ["langchain", "schema", "output"]
def __add__(self, other: ChatGenerationChunk) -> ChatGenerationChunk: if isinstance(other, ChatGenerationChunk): generation_info = merge_dicts( self.generation_info or {}, other.generation_info or {}, ) return ChatGenerationChunk( message=self.message + other.message, generation_info=generation_info or None, ) else: raise TypeError( f"unsupported operand type(s) for +: '{type(self)}' and '{type(other)}'" )