# -*- coding: utf8 -*- # Copyright (c) 2017-2021 THL A29 Limited, a Tencent company. All Rights Reserved. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import warnings from tencentcloud.common.abstract_model import AbstractModel class ActivateServiceRequest(AbstractModel): """ActivateService请求参数结构体 """ def __init__(self): r""" :param _PayMode: 开通之后,是否关闭后付费;默认为0,不关闭;1为关闭 :type PayMode: int """ self._PayMode = None @property def PayMode(self): """开通之后,是否关闭后付费;默认为0,不关闭;1为关闭 :rtype: int """ return self._PayMode @PayMode.setter def PayMode(self, PayMode): self._PayMode = PayMode def _deserialize(self, params): self._PayMode = params.get("PayMode") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ActivateServiceResponse(AbstractModel): """ActivateService返回参数结构体 """ def __init__(self): r""" :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._RequestId = None @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._RequestId = params.get("RequestId") class ChatCompletionsRequest(AbstractModel): """ChatCompletions请求参数结构体 """ def __init__(self): r""" :param _Model: 模型名称,可选值包括 hunyuan-lite、hunyuan-standard、hunyuan-standard-256K、hunyuan-code、hunyuan-role、hunyuan-functioncall、hunyuan-vision、hunyuan-turbo、hunyuan-turbo-latest、hunyuan-turbo-20241223、hunyuan-turbo-20241120、hunyuan-large、hunyuan-large-longcontext、hunyuan-turbo-vision、hunyuan-standard-vision、hunyuan-lite-vision、hunyuan-turbos-20250226、hunyuan-turbos-latest。各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。注意:不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :type Model: str :param _Messages: 聊天上下文信息。 说明: 1. 长度最多为 40,按对话时间从旧到新在数组中排列。 2. Message.Role 可选值:system、user、assistant、 tool(functioncall场景)。 其中,system 角色可选,如存在则必须位于列表的最开始。user(tool) 和 assistant 需交替出现(一问一答),以 user 提问开始,user(tool)提问结束,其中tool可以连续出现多次,且 Content 不能为空。Role 的顺序示例:[system(可选) user assistant user(tool tool ...) assistant user(tool tool ...) ...]。 3. Messages 中 Content 总长度不能超过模型输入长度上限(可参考 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 文档),超过则会截断最前面的内容,只保留尾部内容。 :type Messages: list of Message :param _Stream: 流式调用开关。 说明: 1. 未传值时默认为非流式调用(false)。 2. 流式调用时以 SSE 协议增量返回结果(返回值取 Choices[n].Delta 中的值,需要拼接增量数据才能获得完整结果)。 3. 非流式调用时: 调用方式与普通 HTTP 请求无异。 接口响应耗时较长,**如需更低时延建议设置为 true**。 只返回一次最终结果(返回值取 Choices[n].Message 中的值)。 注意: 通过 SDK 调用时,流式和非流式调用需用**不同的方式**获取返回值,具体参考 SDK 中的注释或示例(在各语言 SDK 代码仓库的 examples/hunyuan/v20230901/ 目录中)。 :type Stream: bool :param _StreamModeration: 流式输出审核开关。 说明: 1. 当使用流式输出(Stream 字段值为 true)时,该字段生效。 2. 输出审核有流式和同步两种模式,**流式模式首包响应更快**。未传值时默认为流式模式(true)。 3. 如果值为 true,将对输出内容进行分段审核,审核通过的内容流式输出返回。如果出现审核不过,响应中的 FinishReason 值为 sensitive。 4. 如果值为 false,则不使用流式输出审核,需要审核完所有输出内容后再返回结果。 注意: 当选择流式输出审核时,可能会出现部分内容已输出,但中间某一段响应中的 FinishReason 值为 sensitive,此时说明安全审核未通过。如果业务场景有实时文字上屏的需求,需要自行撤回已上屏的内容,并建议自定义替换为一条提示语,如 “这个问题我不方便回答,不如我们换个话题试试”,以保障终端体验。 :type StreamModeration: bool :param _TopP: 说明: 1. 影响输出文本的多样性。模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。 2. 取值区间为 [0.0, 1.0]。取值越大,生成文本的多样性越强。 :type TopP: float :param _Temperature: 说明: 1. 影响模型输出多样性,模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。 2. 取值区间为 [0.0, 2.0]。较高的数值会使输出更加多样化和不可预测,而较低的数值会使其更加集中和确定。 :type Temperature: float :param _EnableEnhancement: 功能增强(如搜索)开关。 说明: 1. hunyuan-lite 无功能增强(如搜索)能力,该参数对 hunyuan-lite 版本不生效。 2. 未传值时默认打开开关。 3. 关闭时将直接由主模型生成回复内容,可以降低响应时延(对于流式输出时的首字时延尤为明显)。但在少数场景里,回复效果可能会下降。 4. 安全审核能力不属于功能增强范围,不受此字段影响。 :type EnableEnhancement: bool :param _Tools: 可调用的工具列表,仅对 hunyuan-turbo、hunyuan-functioncall 模型生效。 :type Tools: list of Tool :param _ToolChoice: 工具使用选项,可选值包括 none、auto、custom。说明:1. 仅对 hunyuan-turbo、hunyuan-functioncall 模型生效。2. none:不调用工具;auto:模型自行选择生成回复或调用工具;custom:强制模型调用指定的工具。3. 未设置时,默认值为auto :type ToolChoice: str :param _CustomTool: 强制模型调用指定的工具,当参数ToolChoice为custom时,此参数为必填 :type CustomTool: :class:`tencentcloud.hunyuan.v20230901.models.Tool` :param _SearchInfo: 默认是false,在值为true且命中搜索时,接口会返回SearchInfo :type SearchInfo: bool :param _Citation: 搜索引文角标开关。 说明: 1. 配合EnableEnhancement和SearchInfo参数使用。打开后,回答中命中搜索的结果会在片段后增加角标标志,对应SearchInfo列表中的链接。 2. false:开关关闭,true:开关打开。 3. 未传值时默认开关关闭(false)。 :type Citation: bool :param _EnableSpeedSearch: 是否开启极速版搜索,默认false,不开启;在开启且命中搜索时,会启用极速版搜索,流式输出首字返回更快。 :type EnableSpeedSearch: bool :param _EnableMultimedia: 多媒体开关。 详细介绍请阅读 [多媒体介绍](https://cloud.tencent.com/document/product/1729/111178) 中的说明。 说明: 1. 该参数目前仅对白名单内用户生效,如您想体验该功能请 [联系我们](https://cloud.tencent.com/act/event/Online_service)。 2. 该参数仅在功能增强(如搜索)开关开启(EnableEnhancement=true)并且极速版搜索开关关闭(EnableSpeedSearch=false)时生效。 3. hunyuan-lite 无多媒体能力,该参数对 hunyuan-lite 版本不生效。 4. 未传值时默认关闭。 5. 开启并搜索到对应的多媒体信息时,会输出对应的多媒体地址,可以定制个性化的图文消息。 :type EnableMultimedia: bool :param _EnableDeepSearch: 是否开启深度研究该问题,默认是false,在值为true且命中深度研究该问题时,会返回深度研究该问题信息。 :type EnableDeepSearch: bool :param _Seed: 说明: 1. 确保模型的输出是可复现的。 2. 取值区间为非0正整数,最大值10000。 3. 非必要不建议使用,不合理的取值会影响效果。 :type Seed: int :param _ForceSearchEnhancement: 强制搜索增强开关。 说明: 1. 未传值时默认关闭。 2. 开启后,将强制走AI搜索,当AI搜索结果为空时,由大模型回复兜底话术。 :type ForceSearchEnhancement: bool :param _Stop: 自定义结束生成字符串 调用 OpenAI 的接口时,如果您指定了 `stop` 参数, 模型会停止在匹配到 `stop` 的内容之前。 在调用混元接口时,会停止在匹配到 `stop` 的内容之后。 **说明:** 未来我们可能会修改此行为以便和 OpenAI 保持一致。 但是目前有使用该参数的情况下,开发者需要注意该参数是否会对应用造成影响,以及未来该行为调整时带来的影响。 :type Stop: list of str :param _EnableRecommendedQuestions: 推荐问答开关。 说明: 1. 未传值时默认关闭。 2. 开启后,在返回值的最后一个包中会增加 RecommendedQuestions 字段表示推荐问答, 最多返回3条。 :type EnableRecommendedQuestions: bool :param _EnableDeepRead: 是否开启深度阅读,默认是false,在值为true时,会返回深度阅读的结果信息。说明:1.深度阅读需要开启插件增强,即设置EnableEnhancement为true,当设置EnableDeepRead为true时EnableEnhancement默认为true;2.目前暂时只支持单文档单轮的深度阅读;3.深度阅读功能的文件上传可以使用FilesUploads接口,具体参数详见FilesUploads接口文档 :type EnableDeepRead: bool """ self._Model = None self._Messages = None self._Stream = None self._StreamModeration = None self._TopP = None self._Temperature = None self._EnableEnhancement = None self._Tools = None self._ToolChoice = None self._CustomTool = None self._SearchInfo = None self._Citation = None self._EnableSpeedSearch = None self._EnableMultimedia = None self._EnableDeepSearch = None self._Seed = None self._ForceSearchEnhancement = None self._Stop = None self._EnableRecommendedQuestions = None self._EnableDeepRead = None @property def Model(self): """模型名称,可选值包括 hunyuan-lite、hunyuan-standard、hunyuan-standard-256K、hunyuan-code、hunyuan-role、hunyuan-functioncall、hunyuan-vision、hunyuan-turbo、hunyuan-turbo-latest、hunyuan-turbo-20241223、hunyuan-turbo-20241120、hunyuan-large、hunyuan-large-longcontext、hunyuan-turbo-vision、hunyuan-standard-vision、hunyuan-lite-vision、hunyuan-turbos-20250226、hunyuan-turbos-latest。各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。注意:不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :rtype: str """ return self._Model @Model.setter def Model(self, Model): self._Model = Model @property def Messages(self): """聊天上下文信息。 说明: 1. 长度最多为 40,按对话时间从旧到新在数组中排列。 2. Message.Role 可选值:system、user、assistant、 tool(functioncall场景)。 其中,system 角色可选,如存在则必须位于列表的最开始。user(tool) 和 assistant 需交替出现(一问一答),以 user 提问开始,user(tool)提问结束,其中tool可以连续出现多次,且 Content 不能为空。Role 的顺序示例:[system(可选) user assistant user(tool tool ...) assistant user(tool tool ...) ...]。 3. Messages 中 Content 总长度不能超过模型输入长度上限(可参考 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 文档),超过则会截断最前面的内容,只保留尾部内容。 :rtype: list of Message """ return self._Messages @Messages.setter def Messages(self, Messages): self._Messages = Messages @property def Stream(self): """流式调用开关。 说明: 1. 未传值时默认为非流式调用(false)。 2. 流式调用时以 SSE 协议增量返回结果(返回值取 Choices[n].Delta 中的值,需要拼接增量数据才能获得完整结果)。 3. 非流式调用时: 调用方式与普通 HTTP 请求无异。 接口响应耗时较长,**如需更低时延建议设置为 true**。 只返回一次最终结果(返回值取 Choices[n].Message 中的值)。 注意: 通过 SDK 调用时,流式和非流式调用需用**不同的方式**获取返回值,具体参考 SDK 中的注释或示例(在各语言 SDK 代码仓库的 examples/hunyuan/v20230901/ 目录中)。 :rtype: bool """ return self._Stream @Stream.setter def Stream(self, Stream): self._Stream = Stream @property def StreamModeration(self): """流式输出审核开关。 说明: 1. 当使用流式输出(Stream 字段值为 true)时,该字段生效。 2. 输出审核有流式和同步两种模式,**流式模式首包响应更快**。未传值时默认为流式模式(true)。 3. 如果值为 true,将对输出内容进行分段审核,审核通过的内容流式输出返回。如果出现审核不过,响应中的 FinishReason 值为 sensitive。 4. 如果值为 false,则不使用流式输出审核,需要审核完所有输出内容后再返回结果。 注意: 当选择流式输出审核时,可能会出现部分内容已输出,但中间某一段响应中的 FinishReason 值为 sensitive,此时说明安全审核未通过。如果业务场景有实时文字上屏的需求,需要自行撤回已上屏的内容,并建议自定义替换为一条提示语,如 “这个问题我不方便回答,不如我们换个话题试试”,以保障终端体验。 :rtype: bool """ return self._StreamModeration @StreamModeration.setter def StreamModeration(self, StreamModeration): self._StreamModeration = StreamModeration @property def TopP(self): """说明: 1. 影响输出文本的多样性。模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。 2. 取值区间为 [0.0, 1.0]。取值越大,生成文本的多样性越强。 :rtype: float """ return self._TopP @TopP.setter def TopP(self, TopP): self._TopP = TopP @property def Temperature(self): """说明: 1. 影响模型输出多样性,模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。 2. 取值区间为 [0.0, 2.0]。较高的数值会使输出更加多样化和不可预测,而较低的数值会使其更加集中和确定。 :rtype: float """ return self._Temperature @Temperature.setter def Temperature(self, Temperature): self._Temperature = Temperature @property def EnableEnhancement(self): """功能增强(如搜索)开关。 说明: 1. hunyuan-lite 无功能增强(如搜索)能力,该参数对 hunyuan-lite 版本不生效。 2. 未传值时默认打开开关。 3. 关闭时将直接由主模型生成回复内容,可以降低响应时延(对于流式输出时的首字时延尤为明显)。但在少数场景里,回复效果可能会下降。 4. 安全审核能力不属于功能增强范围,不受此字段影响。 :rtype: bool """ return self._EnableEnhancement @EnableEnhancement.setter def EnableEnhancement(self, EnableEnhancement): self._EnableEnhancement = EnableEnhancement @property def Tools(self): """可调用的工具列表,仅对 hunyuan-turbo、hunyuan-functioncall 模型生效。 :rtype: list of Tool """ return self._Tools @Tools.setter def Tools(self, Tools): self._Tools = Tools @property def ToolChoice(self): """工具使用选项,可选值包括 none、auto、custom。说明:1. 仅对 hunyuan-turbo、hunyuan-functioncall 模型生效。2. none:不调用工具;auto:模型自行选择生成回复或调用工具;custom:强制模型调用指定的工具。3. 未设置时,默认值为auto :rtype: str """ return self._ToolChoice @ToolChoice.setter def ToolChoice(self, ToolChoice): self._ToolChoice = ToolChoice @property def CustomTool(self): """强制模型调用指定的工具,当参数ToolChoice为custom时,此参数为必填 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Tool` """ return self._CustomTool @CustomTool.setter def CustomTool(self, CustomTool): self._CustomTool = CustomTool @property def SearchInfo(self): """默认是false,在值为true且命中搜索时,接口会返回SearchInfo :rtype: bool """ return self._SearchInfo @SearchInfo.setter def SearchInfo(self, SearchInfo): self._SearchInfo = SearchInfo @property def Citation(self): """搜索引文角标开关。 说明: 1. 配合EnableEnhancement和SearchInfo参数使用。打开后,回答中命中搜索的结果会在片段后增加角标标志,对应SearchInfo列表中的链接。 2. false:开关关闭,true:开关打开。 3. 未传值时默认开关关闭(false)。 :rtype: bool """ return self._Citation @Citation.setter def Citation(self, Citation): self._Citation = Citation @property def EnableSpeedSearch(self): """是否开启极速版搜索,默认false,不开启;在开启且命中搜索时,会启用极速版搜索,流式输出首字返回更快。 :rtype: bool """ return self._EnableSpeedSearch @EnableSpeedSearch.setter def EnableSpeedSearch(self, EnableSpeedSearch): self._EnableSpeedSearch = EnableSpeedSearch @property def EnableMultimedia(self): """多媒体开关。 详细介绍请阅读 [多媒体介绍](https://cloud.tencent.com/document/product/1729/111178) 中的说明。 说明: 1. 该参数目前仅对白名单内用户生效,如您想体验该功能请 [联系我们](https://cloud.tencent.com/act/event/Online_service)。 2. 该参数仅在功能增强(如搜索)开关开启(EnableEnhancement=true)并且极速版搜索开关关闭(EnableSpeedSearch=false)时生效。 3. hunyuan-lite 无多媒体能力,该参数对 hunyuan-lite 版本不生效。 4. 未传值时默认关闭。 5. 开启并搜索到对应的多媒体信息时,会输出对应的多媒体地址,可以定制个性化的图文消息。 :rtype: bool """ return self._EnableMultimedia @EnableMultimedia.setter def EnableMultimedia(self, EnableMultimedia): self._EnableMultimedia = EnableMultimedia @property def EnableDeepSearch(self): """是否开启深度研究该问题,默认是false,在值为true且命中深度研究该问题时,会返回深度研究该问题信息。 :rtype: bool """ return self._EnableDeepSearch @EnableDeepSearch.setter def EnableDeepSearch(self, EnableDeepSearch): self._EnableDeepSearch = EnableDeepSearch @property def Seed(self): """说明: 1. 确保模型的输出是可复现的。 2. 取值区间为非0正整数,最大值10000。 3. 非必要不建议使用,不合理的取值会影响效果。 :rtype: int """ return self._Seed @Seed.setter def Seed(self, Seed): self._Seed = Seed @property def ForceSearchEnhancement(self): """强制搜索增强开关。 说明: 1. 未传值时默认关闭。 2. 开启后,将强制走AI搜索,当AI搜索结果为空时,由大模型回复兜底话术。 :rtype: bool """ return self._ForceSearchEnhancement @ForceSearchEnhancement.setter def ForceSearchEnhancement(self, ForceSearchEnhancement): self._ForceSearchEnhancement = ForceSearchEnhancement @property def Stop(self): """自定义结束生成字符串 调用 OpenAI 的接口时,如果您指定了 `stop` 参数, 模型会停止在匹配到 `stop` 的内容之前。 在调用混元接口时,会停止在匹配到 `stop` 的内容之后。 **说明:** 未来我们可能会修改此行为以便和 OpenAI 保持一致。 但是目前有使用该参数的情况下,开发者需要注意该参数是否会对应用造成影响,以及未来该行为调整时带来的影响。 :rtype: list of str """ return self._Stop @Stop.setter def Stop(self, Stop): self._Stop = Stop @property def EnableRecommendedQuestions(self): """推荐问答开关。 说明: 1. 未传值时默认关闭。 2. 开启后,在返回值的最后一个包中会增加 RecommendedQuestions 字段表示推荐问答, 最多返回3条。 :rtype: bool """ return self._EnableRecommendedQuestions @EnableRecommendedQuestions.setter def EnableRecommendedQuestions(self, EnableRecommendedQuestions): self._EnableRecommendedQuestions = EnableRecommendedQuestions @property def EnableDeepRead(self): """是否开启深度阅读,默认是false,在值为true时,会返回深度阅读的结果信息。说明:1.深度阅读需要开启插件增强,即设置EnableEnhancement为true,当设置EnableDeepRead为true时EnableEnhancement默认为true;2.目前暂时只支持单文档单轮的深度阅读;3.深度阅读功能的文件上传可以使用FilesUploads接口,具体参数详见FilesUploads接口文档 :rtype: bool """ return self._EnableDeepRead @EnableDeepRead.setter def EnableDeepRead(self, EnableDeepRead): self._EnableDeepRead = EnableDeepRead def _deserialize(self, params): self._Model = params.get("Model") if params.get("Messages") is not None: self._Messages = [] for item in params.get("Messages"): obj = Message() obj._deserialize(item) self._Messages.append(obj) self._Stream = params.get("Stream") self._StreamModeration = params.get("StreamModeration") self._TopP = params.get("TopP") self._Temperature = params.get("Temperature") self._EnableEnhancement = params.get("EnableEnhancement") if params.get("Tools") is not None: self._Tools = [] for item in params.get("Tools"): obj = Tool() obj._deserialize(item) self._Tools.append(obj) self._ToolChoice = params.get("ToolChoice") if params.get("CustomTool") is not None: self._CustomTool = Tool() self._CustomTool._deserialize(params.get("CustomTool")) self._SearchInfo = params.get("SearchInfo") self._Citation = params.get("Citation") self._EnableSpeedSearch = params.get("EnableSpeedSearch") self._EnableMultimedia = params.get("EnableMultimedia") self._EnableDeepSearch = params.get("EnableDeepSearch") self._Seed = params.get("Seed") self._ForceSearchEnhancement = params.get("ForceSearchEnhancement") self._Stop = params.get("Stop") self._EnableRecommendedQuestions = params.get("EnableRecommendedQuestions") self._EnableDeepRead = params.get("EnableDeepRead") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ChatCompletionsResponse(AbstractModel): """ChatCompletions返回参数结构体 """ def __init__(self): r""" :param _Created: Unix 时间戳,单位为秒。 :type Created: int :param _Usage: Token 统计信息。 按照总 Token 数量计费。 :type Usage: :class:`tencentcloud.hunyuan.v20230901.models.Usage` :param _Note: 免责声明。 :type Note: str :param _Id: 本次请求的 RequestId。 :type Id: str :param _Choices: 回复内容。 :type Choices: list of Choice :param _ErrorMsg: 错误信息。 如果流式返回中服务处理异常,返回该错误信息。 注意:此字段可能返回 null,表示取不到有效值。 :type ErrorMsg: :class:`tencentcloud.hunyuan.v20230901.models.ErrorMsg` :param _ModerationLevel: 多轮会话风险审核,值为1时,表明存在信息安全风险,建议终止客户多轮会话。 :type ModerationLevel: str :param _SearchInfo: 搜索结果信息 :type SearchInfo: :class:`tencentcloud.hunyuan.v20230901.models.SearchInfo` :param _Replaces: 多媒体信息。 说明: 1. 可以用多媒体信息替换回复内容里的占位符,得到完整的消息。 2. 可能会出现回复内容里存在占位符,但是因为审核等原因没有返回多媒体信息。 :type Replaces: list of Replace :param _RecommendedQuestions: 推荐问答。 :type RecommendedQuestions: list of str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._Created = None self._Usage = None self._Note = None self._Id = None self._Choices = None self._ErrorMsg = None self._ModerationLevel = None self._SearchInfo = None self._Replaces = None self._RecommendedQuestions = None self._RequestId = None @property def Created(self): """Unix 时间戳,单位为秒。 :rtype: int """ return self._Created @Created.setter def Created(self, Created): self._Created = Created @property def Usage(self): """Token 统计信息。 按照总 Token 数量计费。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Usage` """ return self._Usage @Usage.setter def Usage(self, Usage): self._Usage = Usage @property def Note(self): """免责声明。 :rtype: str """ return self._Note @Note.setter def Note(self, Note): self._Note = Note @property def Id(self): """本次请求的 RequestId。 :rtype: str """ return self._Id @Id.setter def Id(self, Id): self._Id = Id @property def Choices(self): """回复内容。 :rtype: list of Choice """ return self._Choices @Choices.setter def Choices(self, Choices): self._Choices = Choices @property def ErrorMsg(self): """错误信息。 如果流式返回中服务处理异常,返回该错误信息。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ErrorMsg` """ return self._ErrorMsg @ErrorMsg.setter def ErrorMsg(self, ErrorMsg): self._ErrorMsg = ErrorMsg @property def ModerationLevel(self): warnings.warn("parameter `ModerationLevel` is deprecated", DeprecationWarning) """多轮会话风险审核,值为1时,表明存在信息安全风险,建议终止客户多轮会话。 :rtype: str """ return self._ModerationLevel @ModerationLevel.setter def ModerationLevel(self, ModerationLevel): warnings.warn("parameter `ModerationLevel` is deprecated", DeprecationWarning) self._ModerationLevel = ModerationLevel @property def SearchInfo(self): """搜索结果信息 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.SearchInfo` """ return self._SearchInfo @SearchInfo.setter def SearchInfo(self, SearchInfo): self._SearchInfo = SearchInfo @property def Replaces(self): """多媒体信息。 说明: 1. 可以用多媒体信息替换回复内容里的占位符,得到完整的消息。 2. 可能会出现回复内容里存在占位符,但是因为审核等原因没有返回多媒体信息。 :rtype: list of Replace """ return self._Replaces @Replaces.setter def Replaces(self, Replaces): self._Replaces = Replaces @property def RecommendedQuestions(self): """推荐问答。 :rtype: list of str """ return self._RecommendedQuestions @RecommendedQuestions.setter def RecommendedQuestions(self, RecommendedQuestions): self._RecommendedQuestions = RecommendedQuestions @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._Created = params.get("Created") if params.get("Usage") is not None: self._Usage = Usage() self._Usage._deserialize(params.get("Usage")) self._Note = params.get("Note") self._Id = params.get("Id") if params.get("Choices") is not None: self._Choices = [] for item in params.get("Choices"): obj = Choice() obj._deserialize(item) self._Choices.append(obj) if params.get("ErrorMsg") is not None: self._ErrorMsg = ErrorMsg() self._ErrorMsg._deserialize(params.get("ErrorMsg")) self._ModerationLevel = params.get("ModerationLevel") if params.get("SearchInfo") is not None: self._SearchInfo = SearchInfo() self._SearchInfo._deserialize(params.get("SearchInfo")) if params.get("Replaces") is not None: self._Replaces = [] for item in params.get("Replaces"): obj = Replace() obj._deserialize(item) self._Replaces.append(obj) self._RecommendedQuestions = params.get("RecommendedQuestions") self._RequestId = params.get("RequestId") class ChatTranslationsRequest(AbstractModel): """ChatTranslations请求参数结构体 """ def __init__(self): r""" :param _Model: 模型名称,可选值包括 hunyuan-translation、hunyuan-translation-lite。 各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。 注意: 不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :type Model: str :param _Stream: 流式调用开关。 说明: 1. 未传值时默认为非流式调用(false)。 2. 流式调用时以 SSE 协议增量返回结果(返回值取 Choices[n].Delta 中的值,需要拼接增量数据才能获得完整结果)。 3. 非流式调用时: 调用方式与普通 HTTP 请求无异。 接口响应耗时较长,**如需更低时延建议设置为 true**。 只返回一次最终结果(返回值取 Choices[n].Message 中的值)。 注意: 通过 SDK 调用时,流式和非流式调用需用**不同的方式**获取返回值,具体参考 SDK 中的注释或示例(在各语言 SDK 代码仓库的 examples/hunyuan/v20230901/ 目录中)。 :type Stream: bool :param _Text: 待翻译的文本 :type Text: str :param _Source: 源语言。 支持语言列表: 1. 简体中文:zh,2. 粤语:yue,3. 英语:en,4. 法语:fr,5. 葡萄牙语:pt,6. 西班牙语:es,7. 日语:ja,8. 土耳其语:tr,9. 俄语:ru,10. 阿拉伯语:ar,11. 韩语:ko,12. 泰语:th,13. 意大利语:it,14. 德语:de,15. 越南语:vi,16. 马来语:ms,17. 印尼语:id :type Source: str :param _Target: 目标语言。 支持语言列表: 1. 简体中文:zh,2. 粤语:yue,3. 英语:en,4. 法语:fr,5. 葡萄牙语:pt,6. 西班牙语:es,7. 日语:ja,8. 土耳其语:tr,9. 俄语:ru,10. 阿拉伯语:ar,11. 韩语:ko,12. 泰语:th,13. 意大利语:it,14. 德语:de,15. 越南语:vi,16. 马来语:ms,17. 印尼语:id :type Target: str :param _Field: 待翻译文本所属领域,例如游戏剧情等 :type Field: str :param _References: 参考示例,最多10个 :type References: list of Reference """ self._Model = None self._Stream = None self._Text = None self._Source = None self._Target = None self._Field = None self._References = None @property def Model(self): """模型名称,可选值包括 hunyuan-translation、hunyuan-translation-lite。 各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。 注意: 不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :rtype: str """ return self._Model @Model.setter def Model(self, Model): self._Model = Model @property def Stream(self): """流式调用开关。 说明: 1. 未传值时默认为非流式调用(false)。 2. 流式调用时以 SSE 协议增量返回结果(返回值取 Choices[n].Delta 中的值,需要拼接增量数据才能获得完整结果)。 3. 非流式调用时: 调用方式与普通 HTTP 请求无异。 接口响应耗时较长,**如需更低时延建议设置为 true**。 只返回一次最终结果(返回值取 Choices[n].Message 中的值)。 注意: 通过 SDK 调用时,流式和非流式调用需用**不同的方式**获取返回值,具体参考 SDK 中的注释或示例(在各语言 SDK 代码仓库的 examples/hunyuan/v20230901/ 目录中)。 :rtype: bool """ return self._Stream @Stream.setter def Stream(self, Stream): self._Stream = Stream @property def Text(self): """待翻译的文本 :rtype: str """ return self._Text @Text.setter def Text(self, Text): self._Text = Text @property def Source(self): """源语言。 支持语言列表: 1. 简体中文:zh,2. 粤语:yue,3. 英语:en,4. 法语:fr,5. 葡萄牙语:pt,6. 西班牙语:es,7. 日语:ja,8. 土耳其语:tr,9. 俄语:ru,10. 阿拉伯语:ar,11. 韩语:ko,12. 泰语:th,13. 意大利语:it,14. 德语:de,15. 越南语:vi,16. 马来语:ms,17. 印尼语:id :rtype: str """ return self._Source @Source.setter def Source(self, Source): self._Source = Source @property def Target(self): """目标语言。 支持语言列表: 1. 简体中文:zh,2. 粤语:yue,3. 英语:en,4. 法语:fr,5. 葡萄牙语:pt,6. 西班牙语:es,7. 日语:ja,8. 土耳其语:tr,9. 俄语:ru,10. 阿拉伯语:ar,11. 韩语:ko,12. 泰语:th,13. 意大利语:it,14. 德语:de,15. 越南语:vi,16. 马来语:ms,17. 印尼语:id :rtype: str """ return self._Target @Target.setter def Target(self, Target): self._Target = Target @property def Field(self): """待翻译文本所属领域,例如游戏剧情等 :rtype: str """ return self._Field @Field.setter def Field(self, Field): self._Field = Field @property def References(self): """参考示例,最多10个 :rtype: list of Reference """ return self._References @References.setter def References(self, References): self._References = References def _deserialize(self, params): self._Model = params.get("Model") self._Stream = params.get("Stream") self._Text = params.get("Text") self._Source = params.get("Source") self._Target = params.get("Target") self._Field = params.get("Field") if params.get("References") is not None: self._References = [] for item in params.get("References"): obj = Reference() obj._deserialize(item) self._References.append(obj) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ChatTranslationsResponse(AbstractModel): """ChatTranslations返回参数结构体 """ def __init__(self): r""" :param _Id: 本次请求的 RequestId。 :type Id: str :param _Note: 免责声明。 :type Note: str :param _Created: Unix 时间戳,单位为秒。 :type Created: int :param _Usage: Token 统计信息。 按照总 Token 数量计费。 :type Usage: :class:`tencentcloud.hunyuan.v20230901.models.Usage` :param _Choices: 回复内容。 :type Choices: list of TranslationChoice :param _ErrorMsg: 错误信息。 如果流式返回中服务处理异常,返回该错误信息。 :type ErrorMsg: :class:`tencentcloud.hunyuan.v20230901.models.ErrorMsg` :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._Id = None self._Note = None self._Created = None self._Usage = None self._Choices = None self._ErrorMsg = None self._RequestId = None @property def Id(self): """本次请求的 RequestId。 :rtype: str """ return self._Id @Id.setter def Id(self, Id): self._Id = Id @property def Note(self): """免责声明。 :rtype: str """ return self._Note @Note.setter def Note(self, Note): self._Note = Note @property def Created(self): """Unix 时间戳,单位为秒。 :rtype: int """ return self._Created @Created.setter def Created(self, Created): self._Created = Created @property def Usage(self): """Token 统计信息。 按照总 Token 数量计费。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Usage` """ return self._Usage @Usage.setter def Usage(self, Usage): self._Usage = Usage @property def Choices(self): """回复内容。 :rtype: list of TranslationChoice """ return self._Choices @Choices.setter def Choices(self, Choices): self._Choices = Choices @property def ErrorMsg(self): """错误信息。 如果流式返回中服务处理异常,返回该错误信息。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ErrorMsg` """ return self._ErrorMsg @ErrorMsg.setter def ErrorMsg(self, ErrorMsg): self._ErrorMsg = ErrorMsg @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._Id = params.get("Id") self._Note = params.get("Note") self._Created = params.get("Created") if params.get("Usage") is not None: self._Usage = Usage() self._Usage._deserialize(params.get("Usage")) if params.get("Choices") is not None: self._Choices = [] for item in params.get("Choices"): obj = TranslationChoice() obj._deserialize(item) self._Choices.append(obj) if params.get("ErrorMsg") is not None: self._ErrorMsg = ErrorMsg() self._ErrorMsg._deserialize(params.get("ErrorMsg")) self._RequestId = params.get("RequestId") class Choice(AbstractModel): """返回的回复, 支持多个 """ def __init__(self): r""" :param _FinishReason: 结束标志位,可能为 stop、 sensitive或者tool_calls。 stop 表示输出正常结束。 sensitive 只在开启流式输出审核时会出现,表示安全审核未通过。 tool_calls 标识函数调用。 :type FinishReason: str :param _Delta: 增量返回值,流式调用时使用该字段。 注意:此字段可能返回 null,表示取不到有效值。 :type Delta: :class:`tencentcloud.hunyuan.v20230901.models.Delta` :param _Message: 返回值,非流式调用时使用该字段。 注意:此字段可能返回 null,表示取不到有效值。 :type Message: :class:`tencentcloud.hunyuan.v20230901.models.Message` :param _Index: 索引值,流式调用时使用该字段。 :type Index: int :param _ModerationLevel: 多轮会话风险审核,值为1时,表明存在信息安全风险,建议终止客户多轮会话。 :type ModerationLevel: str """ self._FinishReason = None self._Delta = None self._Message = None self._Index = None self._ModerationLevel = None @property def FinishReason(self): """结束标志位,可能为 stop、 sensitive或者tool_calls。 stop 表示输出正常结束。 sensitive 只在开启流式输出审核时会出现,表示安全审核未通过。 tool_calls 标识函数调用。 :rtype: str """ return self._FinishReason @FinishReason.setter def FinishReason(self, FinishReason): self._FinishReason = FinishReason @property def Delta(self): """增量返回值,流式调用时使用该字段。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Delta` """ return self._Delta @Delta.setter def Delta(self, Delta): self._Delta = Delta @property def Message(self): """返回值,非流式调用时使用该字段。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Message` """ return self._Message @Message.setter def Message(self, Message): self._Message = Message @property def Index(self): """索引值,流式调用时使用该字段。 :rtype: int """ return self._Index @Index.setter def Index(self, Index): self._Index = Index @property def ModerationLevel(self): """多轮会话风险审核,值为1时,表明存在信息安全风险,建议终止客户多轮会话。 :rtype: str """ return self._ModerationLevel @ModerationLevel.setter def ModerationLevel(self, ModerationLevel): self._ModerationLevel = ModerationLevel def _deserialize(self, params): self._FinishReason = params.get("FinishReason") if params.get("Delta") is not None: self._Delta = Delta() self._Delta._deserialize(params.get("Delta")) if params.get("Message") is not None: self._Message = Message() self._Message._deserialize(params.get("Message")) self._Index = params.get("Index") self._ModerationLevel = params.get("ModerationLevel") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Content(AbstractModel): """可以传入多种类型的内容,如图片或文本。 """ def __init__(self): r""" :param _Type: 内容类型 注意: 需包含至少一个 Type 为"text"的参数及至少一个 Type 为"image_url"的参数。 参数值可选范围:[text", "image_url"] 注意:此字段可能返回 null,表示取不到有效值。 :type Type: str :param _Text: 当 Type 为 text 时使用,表示具体的文本内容。当 Type 为 image_url 时,当前字段内容需保持为空,传递内容不生效。 注意:此字段可能返回 null,表示取不到有效值。 :type Text: str :param _ImageUrl: 图片的url,当 Type 为 image_url 时使用,表示具体的图片内容 如"https://example.com/1.png" 或 图片的base64(注意 "data:image/jpeg;base64," 为必要部分):"......"。当 Type 为 text 时,当前字段内容需保持为空,传递内容不生效。 注意:此字段可能返回 null,表示取不到有效值。 :type ImageUrl: :class:`tencentcloud.hunyuan.v20230901.models.ImageUrl` """ self._Type = None self._Text = None self._ImageUrl = None @property def Type(self): """内容类型 注意: 需包含至少一个 Type 为"text"的参数及至少一个 Type 为"image_url"的参数。 参数值可选范围:[text", "image_url"] 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Type @Type.setter def Type(self, Type): self._Type = Type @property def Text(self): """当 Type 为 text 时使用,表示具体的文本内容。当 Type 为 image_url 时,当前字段内容需保持为空,传递内容不生效。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Text @Text.setter def Text(self, Text): self._Text = Text @property def ImageUrl(self): """图片的url,当 Type 为 image_url 时使用,表示具体的图片内容 如"https://example.com/1.png" 或 图片的base64(注意 "data:image/jpeg;base64," 为必要部分):"......"。当 Type 为 text 时,当前字段内容需保持为空,传递内容不生效。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ImageUrl` """ return self._ImageUrl @ImageUrl.setter def ImageUrl(self, ImageUrl): self._ImageUrl = ImageUrl def _deserialize(self, params): self._Type = params.get("Type") self._Text = params.get("Text") if params.get("ImageUrl") is not None: self._ImageUrl = ImageUrl() self._ImageUrl._deserialize(params.get("ImageUrl")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class CreateThreadRequest(AbstractModel): """CreateThread请求参数结构体 """ class CreateThreadResponse(AbstractModel): """CreateThread返回参数结构体 """ def __init__(self): r""" :param _ID: 会话 ID :type ID: str :param _Object: 对象类型 :type Object: str :param _CreatedAt: 创建时间,Unix 时间戳,单位为秒。 :type CreatedAt: int :param _ToolResources: 提供给工具的资源列表 注意:此字段可能返回 null,表示取不到有效值。 :type ToolResources: :class:`tencentcloud.hunyuan.v20230901.models.ThreadToolResources` :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._ID = None self._Object = None self._CreatedAt = None self._ToolResources = None self._RequestId = None @property def ID(self): """会话 ID :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def CreatedAt(self): """创建时间,Unix 时间戳,单位为秒。 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def ToolResources(self): """提供给工具的资源列表 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ThreadToolResources` """ return self._ToolResources @ToolResources.setter def ToolResources(self, ToolResources): self._ToolResources = ToolResources @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._CreatedAt = params.get("CreatedAt") if params.get("ToolResources") is not None: self._ToolResources = ThreadToolResources() self._ToolResources._deserialize(params.get("ToolResources")) self._RequestId = params.get("RequestId") class Delta(AbstractModel): """返回的内容(流式返回) """ def __init__(self): r""" :param _Role: 角色名称。 :type Role: str :param _Content: 内容详情。 :type Content: str :param _ToolCalls: 模型生成的工具调用,仅 hunyuan-functioncall 模型支持 说明: 对于每一次的输出值应该以Id为标识对Type、Name、Arguments字段进行合并。 注意:此字段可能返回 null,表示取不到有效值。 :type ToolCalls: list of ToolCall """ self._Role = None self._Content = None self._ToolCalls = None @property def Role(self): """角色名称。 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """内容详情。 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def ToolCalls(self): """模型生成的工具调用,仅 hunyuan-functioncall 模型支持 说明: 对于每一次的输出值应该以Id为标识对Type、Name、Arguments字段进行合并。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of ToolCall """ return self._ToolCalls @ToolCalls.setter def ToolCalls(self, ToolCalls): self._ToolCalls = ToolCalls def _deserialize(self, params): self._Role = params.get("Role") self._Content = params.get("Content") if params.get("ToolCalls") is not None: self._ToolCalls = [] for item in params.get("ToolCalls"): obj = ToolCall() obj._deserialize(item) self._ToolCalls.append(obj) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class EmbeddingData(AbstractModel): """Embedding 信息。 """ def __init__(self): r""" :param _Embedding: Embedding 信息,目前为 1024 维浮点数。 注意:此字段可能返回 null,表示取不到有效值。 :type Embedding: list of float :param _Index: 下标,目前不支持批量,因此固定为 0。 注意:此字段可能返回 null,表示取不到有效值。 :type Index: int :param _Object: 目前固定为 "embedding"。 注意:此字段可能返回 null,表示取不到有效值。 :type Object: str """ self._Embedding = None self._Index = None self._Object = None @property def Embedding(self): """Embedding 信息,目前为 1024 维浮点数。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of float """ return self._Embedding @Embedding.setter def Embedding(self, Embedding): self._Embedding = Embedding @property def Index(self): """下标,目前不支持批量,因此固定为 0。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._Index @Index.setter def Index(self, Index): self._Index = Index @property def Object(self): """目前固定为 "embedding"。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object def _deserialize(self, params): self._Embedding = params.get("Embedding") self._Index = params.get("Index") self._Object = params.get("Object") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class EmbeddingUsage(AbstractModel): """Token 使用计数。 """ def __init__(self): r""" :param _PromptTokens: 输入 Token 数。 :type PromptTokens: int :param _TotalTokens: 总 Token 数。 :type TotalTokens: int """ self._PromptTokens = None self._TotalTokens = None @property def PromptTokens(self): """输入 Token 数。 :rtype: int """ return self._PromptTokens @PromptTokens.setter def PromptTokens(self, PromptTokens): self._PromptTokens = PromptTokens @property def TotalTokens(self): """总 Token 数。 :rtype: int """ return self._TotalTokens @TotalTokens.setter def TotalTokens(self, TotalTokens): self._TotalTokens = TotalTokens def _deserialize(self, params): self._PromptTokens = params.get("PromptTokens") self._TotalTokens = params.get("TotalTokens") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ErrorMsg(AbstractModel): """运行时异常信息。 """ def __init__(self): r""" :param _Msg: 错误提示信息。 :type Msg: str :param _Code: 错误码。 4000 服务内部异常。 4001 请求模型超时。 :type Code: int """ self._Msg = None self._Code = None @property def Msg(self): """错误提示信息。 :rtype: str """ return self._Msg @Msg.setter def Msg(self, Msg): self._Msg = Msg @property def Code(self): """错误码。 4000 服务内部异常。 4001 请求模型超时。 :rtype: int """ return self._Code @Code.setter def Code(self, Code): self._Code = Code def _deserialize(self, params): self._Msg = params.get("Msg") self._Code = params.get("Code") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class FileObject(AbstractModel): """已上传的文件对象。 """ def __init__(self): r""" :param _ID: 文件标识符,可在各个API中引用。 :type ID: str :param _Object: 对象类型,始终为 file。 :type Object: str :param _Bytes: 文件大小,单位为字节。 :type Bytes: int :param _CreatedAt: 文件创建时的 Unix 时间戳(秒)。 :type CreatedAt: int :param _Filename: 文件名。 :type Filename: str :param _Purpose: 上传文件的用途。 :type Purpose: str """ self._ID = None self._Object = None self._Bytes = None self._CreatedAt = None self._Filename = None self._Purpose = None @property def ID(self): """文件标识符,可在各个API中引用。 :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型,始终为 file。 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def Bytes(self): """文件大小,单位为字节。 :rtype: int """ return self._Bytes @Bytes.setter def Bytes(self, Bytes): self._Bytes = Bytes @property def CreatedAt(self): """文件创建时的 Unix 时间戳(秒)。 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def Filename(self): """文件名。 :rtype: str """ return self._Filename @Filename.setter def Filename(self, Filename): self._Filename = Filename @property def Purpose(self): """上传文件的用途。 :rtype: str """ return self._Purpose @Purpose.setter def Purpose(self, Purpose): self._Purpose = Purpose def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._Bytes = params.get("Bytes") self._CreatedAt = params.get("CreatedAt") self._Filename = params.get("Filename") self._Purpose = params.get("Purpose") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class FilesDeletionsRequest(AbstractModel): """FilesDeletions请求参数结构体 """ def __init__(self): r""" :param _ID: 文件标识符。 :type ID: str """ self._ID = None @property def ID(self): """文件标识符。 :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID def _deserialize(self, params): self._ID = params.get("ID") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class FilesDeletionsResponse(AbstractModel): """FilesDeletions返回参数结构体 """ def __init__(self): r""" :param _ID: 文件标识符。 :type ID: str :param _Object: 对象类型,始终为 file。 :type Object: str :param _Deleted: 是否删除成功。 :type Deleted: bool :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._ID = None self._Object = None self._Deleted = None self._RequestId = None @property def ID(self): """文件标识符。 :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型,始终为 file。 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def Deleted(self): """是否删除成功。 :rtype: bool """ return self._Deleted @Deleted.setter def Deleted(self, Deleted): self._Deleted = Deleted @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._Deleted = params.get("Deleted") self._RequestId = params.get("RequestId") class FilesListRequest(AbstractModel): """FilesList请求参数结构体 """ def __init__(self): r""" :param _Offset: 分页偏移量。 :type Offset: int :param _Limit: 每页数量,最大 100。 :type Limit: int """ self._Offset = None self._Limit = None @property def Offset(self): """分页偏移量。 :rtype: int """ return self._Offset @Offset.setter def Offset(self, Offset): self._Offset = Offset @property def Limit(self): """每页数量,最大 100。 :rtype: int """ return self._Limit @Limit.setter def Limit(self, Limit): self._Limit = Limit def _deserialize(self, params): self._Offset = params.get("Offset") self._Limit = params.get("Limit") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class FilesListResponse(AbstractModel): """FilesList返回参数结构体 """ def __init__(self): r""" :param _Total: 文件数量。 :type Total: int :param _Object: 对象类型,始终为 list。 :type Object: str :param _Data: FileObject 列表。 :type Data: list of FileObject :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._Total = None self._Object = None self._Data = None self._RequestId = None @property def Total(self): """文件数量。 :rtype: int """ return self._Total @Total.setter def Total(self, Total): self._Total = Total @property def Object(self): """对象类型,始终为 list。 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def Data(self): """FileObject 列表。 :rtype: list of FileObject """ return self._Data @Data.setter def Data(self, Data): self._Data = Data @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._Total = params.get("Total") self._Object = params.get("Object") if params.get("Data") is not None: self._Data = [] for item in params.get("Data"): obj = FileObject() obj._deserialize(item) self._Data.append(obj) self._RequestId = params.get("RequestId") class FilesUploadsRequest(AbstractModel): """FilesUploads请求参数结构体 """ def __init__(self): r""" :param _Name: 文件名。 :type Name: str :param _URL: 文件链接。目前支持 csv, doc, docx, pdf, ppt, pptx, txt, xls, xlsx 格式,单文件大小限制为100M。 :type URL: str """ self._Name = None self._URL = None @property def Name(self): """文件名。 :rtype: str """ return self._Name @Name.setter def Name(self, Name): self._Name = Name @property def URL(self): """文件链接。目前支持 csv, doc, docx, pdf, ppt, pptx, txt, xls, xlsx 格式,单文件大小限制为100M。 :rtype: str """ return self._URL @URL.setter def URL(self, URL): self._URL = URL def _deserialize(self, params): self._Name = params.get("Name") self._URL = params.get("URL") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class FilesUploadsResponse(AbstractModel): """FilesUploads返回参数结构体 """ def __init__(self): r""" :param _ID: 文件标识符,可在各个API中引用。 :type ID: str :param _Object: 对象类型,始终为 file。 :type Object: str :param _Bytes: 文件大小,单位为字节。 :type Bytes: int :param _CreatedAt: 文件创建时的 Unix 时间戳(秒)。 :type CreatedAt: int :param _Filename: 文件名。 :type Filename: str :param _Purpose: 上传文件的用途。 :type Purpose: str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._ID = None self._Object = None self._Bytes = None self._CreatedAt = None self._Filename = None self._Purpose = None self._RequestId = None @property def ID(self): """文件标识符,可在各个API中引用。 :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型,始终为 file。 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def Bytes(self): """文件大小,单位为字节。 :rtype: int """ return self._Bytes @Bytes.setter def Bytes(self, Bytes): self._Bytes = Bytes @property def CreatedAt(self): """文件创建时的 Unix 时间戳(秒)。 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def Filename(self): """文件名。 :rtype: str """ return self._Filename @Filename.setter def Filename(self, Filename): self._Filename = Filename @property def Purpose(self): """上传文件的用途。 :rtype: str """ return self._Purpose @Purpose.setter def Purpose(self, Purpose): self._Purpose = Purpose @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._Bytes = params.get("Bytes") self._CreatedAt = params.get("CreatedAt") self._Filename = params.get("Filename") self._Purpose = params.get("Purpose") self._RequestId = params.get("RequestId") class GetEmbeddingRequest(AbstractModel): """GetEmbedding请求参数结构体 """ def __init__(self): r""" :param _Input: 输入文本。总长度不超过 1024 个 Token,超过则会截断最后面的内容。 :type Input: str :param _InputList: 输入文本数组。输入数组总长度不超过 200 。 :type InputList: list of str """ self._Input = None self._InputList = None @property def Input(self): """输入文本。总长度不超过 1024 个 Token,超过则会截断最后面的内容。 :rtype: str """ return self._Input @Input.setter def Input(self, Input): self._Input = Input @property def InputList(self): """输入文本数组。输入数组总长度不超过 200 。 :rtype: list of str """ return self._InputList @InputList.setter def InputList(self, InputList): self._InputList = InputList def _deserialize(self, params): self._Input = params.get("Input") self._InputList = params.get("InputList") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class GetEmbeddingResponse(AbstractModel): """GetEmbedding返回参数结构体 """ def __init__(self): r""" :param _Data: 返回的 Embedding 信息。 :type Data: list of EmbeddingData :param _Usage: Token 使用计数,按照总 Token 数量收费。 :type Usage: :class:`tencentcloud.hunyuan.v20230901.models.EmbeddingUsage` :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._Data = None self._Usage = None self._RequestId = None @property def Data(self): """返回的 Embedding 信息。 :rtype: list of EmbeddingData """ return self._Data @Data.setter def Data(self, Data): self._Data = Data @property def Usage(self): """Token 使用计数,按照总 Token 数量收费。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.EmbeddingUsage` """ return self._Usage @Usage.setter def Usage(self, Usage): self._Usage = Usage @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): if params.get("Data") is not None: self._Data = [] for item in params.get("Data"): obj = EmbeddingData() obj._deserialize(item) self._Data.append(obj) if params.get("Usage") is not None: self._Usage = EmbeddingUsage() self._Usage._deserialize(params.get("Usage")) self._RequestId = params.get("RequestId") class GetThreadMessageListRequest(AbstractModel): """GetThreadMessageList请求参数结构体 """ def __init__(self): r""" :param _ThreadID: 会话 ID :type ThreadID: str :param _Limit: 返回的消息条数,1 - 100 条 :type Limit: int :param _Order: 排序方式,按创建时间升序(asc)或降序(desc),默认为 desc :type Order: str """ self._ThreadID = None self._Limit = None self._Order = None @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID @property def Limit(self): """返回的消息条数,1 - 100 条 :rtype: int """ return self._Limit @Limit.setter def Limit(self, Limit): self._Limit = Limit @property def Order(self): """排序方式,按创建时间升序(asc)或降序(desc),默认为 desc :rtype: str """ return self._Order @Order.setter def Order(self, Order): self._Order = Order def _deserialize(self, params): self._ThreadID = params.get("ThreadID") self._Limit = params.get("Limit") self._Order = params.get("Order") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class GetThreadMessageListResponse(AbstractModel): """GetThreadMessageList返回参数结构体 """ def __init__(self): r""" :param _Data: 消息列表 :type Data: list of ThreadMessage :param _FirstID: 第一条消息 ID 注意:此字段可能返回 null,表示取不到有效值。 :type FirstID: str :param _LastID: 已废弃 注意:此字段可能返回 null,表示取不到有效值。 :type LastID: int :param _HasMore: 是否还有更多消息 :type HasMore: bool :param _Object: 对象类型 :type Object: str :param _FirstMsgID: 第一条消息 ID :type FirstMsgID: str :param _LastMsgID: 最后一条消息 ID :type LastMsgID: str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._Data = None self._FirstID = None self._LastID = None self._HasMore = None self._Object = None self._FirstMsgID = None self._LastMsgID = None self._RequestId = None @property def Data(self): """消息列表 :rtype: list of ThreadMessage """ return self._Data @Data.setter def Data(self, Data): self._Data = Data @property def FirstID(self): warnings.warn("parameter `FirstID` is deprecated", DeprecationWarning) """第一条消息 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._FirstID @FirstID.setter def FirstID(self, FirstID): warnings.warn("parameter `FirstID` is deprecated", DeprecationWarning) self._FirstID = FirstID @property def LastID(self): warnings.warn("parameter `LastID` is deprecated", DeprecationWarning) """已废弃 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._LastID @LastID.setter def LastID(self, LastID): warnings.warn("parameter `LastID` is deprecated", DeprecationWarning) self._LastID = LastID @property def HasMore(self): """是否还有更多消息 :rtype: bool """ return self._HasMore @HasMore.setter def HasMore(self, HasMore): self._HasMore = HasMore @property def Object(self): """对象类型 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def FirstMsgID(self): """第一条消息 ID :rtype: str """ return self._FirstMsgID @FirstMsgID.setter def FirstMsgID(self, FirstMsgID): self._FirstMsgID = FirstMsgID @property def LastMsgID(self): """最后一条消息 ID :rtype: str """ return self._LastMsgID @LastMsgID.setter def LastMsgID(self, LastMsgID): self._LastMsgID = LastMsgID @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): if params.get("Data") is not None: self._Data = [] for item in params.get("Data"): obj = ThreadMessage() obj._deserialize(item) self._Data.append(obj) self._FirstID = params.get("FirstID") self._LastID = params.get("LastID") self._HasMore = params.get("HasMore") self._Object = params.get("Object") self._FirstMsgID = params.get("FirstMsgID") self._LastMsgID = params.get("LastMsgID") self._RequestId = params.get("RequestId") class GetThreadMessageRequest(AbstractModel): """GetThreadMessage请求参数结构体 """ def __init__(self): r""" :param _ThreadID: 会话 ID :type ThreadID: str :param _MessageID: 消息 ID :type MessageID: str """ self._ThreadID = None self._MessageID = None @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID @property def MessageID(self): """消息 ID :rtype: str """ return self._MessageID @MessageID.setter def MessageID(self, MessageID): self._MessageID = MessageID def _deserialize(self, params): self._ThreadID = params.get("ThreadID") self._MessageID = params.get("MessageID") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class GetThreadMessageResponse(AbstractModel): """GetThreadMessage返回参数结构体 """ def __init__(self): r""" :param _ID: 消息 ID :type ID: str :param _Object: 对象类型 :type Object: str :param _CreatedAt: 创建时间 :type CreatedAt: int :param _ThreadID: 会话 ID :type ThreadID: str :param _Status: 状态,处理中 in_progress,已完成 completed,未完成 incomplete。 :type Status: str :param _InCompleteDetails: 未完成原因 注意:此字段可能返回 null,表示取不到有效值。 :type InCompleteDetails: :class:`tencentcloud.hunyuan.v20230901.models.ThreadMessageInCompleteDetailsObject` :param _CompletedAt: 完成时间 注意:此字段可能返回 null,表示取不到有效值。 :type CompletedAt: int :param _InCompleteAt: 未完成时间 注意:此字段可能返回 null,表示取不到有效值。 :type InCompleteAt: int :param _Role: 角色 :type Role: str :param _Content: 内容 :type Content: str :param _AssistantID: 助手 ID 注意:此字段可能返回 null,表示取不到有效值。 :type AssistantID: str :param _RunID: 运行 ID 注意:此字段可能返回 null,表示取不到有效值。 :type RunID: str :param _Attachments: 附件 注意:此字段可能返回 null,表示取不到有效值。 :type Attachments: list of ThreadMessageAttachmentObject :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._ID = None self._Object = None self._CreatedAt = None self._ThreadID = None self._Status = None self._InCompleteDetails = None self._CompletedAt = None self._InCompleteAt = None self._Role = None self._Content = None self._AssistantID = None self._RunID = None self._Attachments = None self._RequestId = None @property def ID(self): """消息 ID :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def CreatedAt(self): """创建时间 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID @property def Status(self): """状态,处理中 in_progress,已完成 completed,未完成 incomplete。 :rtype: str """ return self._Status @Status.setter def Status(self, Status): self._Status = Status @property def InCompleteDetails(self): """未完成原因 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ThreadMessageInCompleteDetailsObject` """ return self._InCompleteDetails @InCompleteDetails.setter def InCompleteDetails(self, InCompleteDetails): self._InCompleteDetails = InCompleteDetails @property def CompletedAt(self): """完成时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._CompletedAt @CompletedAt.setter def CompletedAt(self, CompletedAt): self._CompletedAt = CompletedAt @property def InCompleteAt(self): """未完成时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._InCompleteAt @InCompleteAt.setter def InCompleteAt(self, InCompleteAt): self._InCompleteAt = InCompleteAt @property def Role(self): """角色 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """内容 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def AssistantID(self): """助手 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._AssistantID @AssistantID.setter def AssistantID(self, AssistantID): self._AssistantID = AssistantID @property def RunID(self): """运行 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._RunID @RunID.setter def RunID(self, RunID): self._RunID = RunID @property def Attachments(self): """附件 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of ThreadMessageAttachmentObject """ return self._Attachments @Attachments.setter def Attachments(self, Attachments): self._Attachments = Attachments @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._CreatedAt = params.get("CreatedAt") self._ThreadID = params.get("ThreadID") self._Status = params.get("Status") if params.get("InCompleteDetails") is not None: self._InCompleteDetails = ThreadMessageInCompleteDetailsObject() self._InCompleteDetails._deserialize(params.get("InCompleteDetails")) self._CompletedAt = params.get("CompletedAt") self._InCompleteAt = params.get("InCompleteAt") self._Role = params.get("Role") self._Content = params.get("Content") self._AssistantID = params.get("AssistantID") self._RunID = params.get("RunID") if params.get("Attachments") is not None: self._Attachments = [] for item in params.get("Attachments"): obj = ThreadMessageAttachmentObject() obj._deserialize(item) self._Attachments.append(obj) self._RequestId = params.get("RequestId") class GetThreadRequest(AbstractModel): """GetThread请求参数结构体 """ def __init__(self): r""" :param _ThreadID: 会话 ID :type ThreadID: str """ self._ThreadID = None @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID def _deserialize(self, params): self._ThreadID = params.get("ThreadID") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class GetThreadResponse(AbstractModel): """GetThread返回参数结构体 """ def __init__(self): r""" :param _ID: 会话 ID :type ID: str :param _Object: 对象类型 :type Object: str :param _CreatedAt: 创建时间,Unix 时间戳,单位为秒。 :type CreatedAt: int :param _ToolResources: 提供给工具的资源列表 注意:此字段可能返回 null,表示取不到有效值。 :type ToolResources: :class:`tencentcloud.hunyuan.v20230901.models.ThreadToolResources` :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._ID = None self._Object = None self._CreatedAt = None self._ToolResources = None self._RequestId = None @property def ID(self): """会话 ID :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def CreatedAt(self): """创建时间,Unix 时间戳,单位为秒。 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def ToolResources(self): """提供给工具的资源列表 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ThreadToolResources` """ return self._ToolResources @ToolResources.setter def ToolResources(self, ToolResources): self._ToolResources = ToolResources @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._CreatedAt = params.get("CreatedAt") if params.get("ToolResources") is not None: self._ToolResources = ThreadToolResources() self._ToolResources._deserialize(params.get("ToolResources")) self._RequestId = params.get("RequestId") class GetTokenCountRequest(AbstractModel): """GetTokenCount请求参数结构体 """ def __init__(self): r""" :param _Prompt: 输入文本 :type Prompt: str """ self._Prompt = None @property def Prompt(self): """输入文本 :rtype: str """ return self._Prompt @Prompt.setter def Prompt(self, Prompt): self._Prompt = Prompt def _deserialize(self, params): self._Prompt = params.get("Prompt") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class GetTokenCountResponse(AbstractModel): """GetTokenCount返回参数结构体 """ def __init__(self): r""" :param _TokenCount: token计数 :type TokenCount: int :param _CharacterCount: 字符计数 :type CharacterCount: int :param _Tokens: 切分后的列表 :type Tokens: list of str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._TokenCount = None self._CharacterCount = None self._Tokens = None self._RequestId = None @property def TokenCount(self): """token计数 :rtype: int """ return self._TokenCount @TokenCount.setter def TokenCount(self, TokenCount): self._TokenCount = TokenCount @property def CharacterCount(self): """字符计数 :rtype: int """ return self._CharacterCount @CharacterCount.setter def CharacterCount(self, CharacterCount): self._CharacterCount = CharacterCount @property def Tokens(self): """切分后的列表 :rtype: list of str """ return self._Tokens @Tokens.setter def Tokens(self, Tokens): self._Tokens = Tokens @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._TokenCount = params.get("TokenCount") self._CharacterCount = params.get("CharacterCount") self._Tokens = params.get("Tokens") self._RequestId = params.get("RequestId") class History(AbstractModel): """混元生图多轮对话历史记录。 """ def __init__(self): r""" :param _ChatId: 对话的 ID,用于唯一标识一轮对话 注意:此字段可能返回 null,表示取不到有效值。 :type ChatId: str :param _Prompt: 原始输入的 Prompt 文本 注意:此字段可能返回 null,表示取不到有效值。 :type Prompt: str :param _RevisedPrompt: 扩写后的 Prompt 文本 注意:此字段可能返回 null,表示取不到有效值。 :type RevisedPrompt: str :param _Seed: 生成图的随机种子 注意:此字段可能返回 null,表示取不到有效值。 :type Seed: int """ self._ChatId = None self._Prompt = None self._RevisedPrompt = None self._Seed = None @property def ChatId(self): """对话的 ID,用于唯一标识一轮对话 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._ChatId @ChatId.setter def ChatId(self, ChatId): self._ChatId = ChatId @property def Prompt(self): """原始输入的 Prompt 文本 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Prompt @Prompt.setter def Prompt(self, Prompt): self._Prompt = Prompt @property def RevisedPrompt(self): """扩写后的 Prompt 文本 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._RevisedPrompt @RevisedPrompt.setter def RevisedPrompt(self, RevisedPrompt): self._RevisedPrompt = RevisedPrompt @property def Seed(self): """生成图的随机种子 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._Seed @Seed.setter def Seed(self, Seed): self._Seed = Seed def _deserialize(self, params): self._ChatId = params.get("ChatId") self._Prompt = params.get("Prompt") self._RevisedPrompt = params.get("RevisedPrompt") self._Seed = params.get("Seed") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ImageUrl(AbstractModel): """具体的图片内容 """ def __init__(self): r""" :param _Url: 图片的 Url(以 http:// 或 https:// 开头) 注意:此字段可能返回 null,表示取不到有效值。 :type Url: str """ self._Url = None @property def Url(self): """图片的 Url(以 http:// 或 https:// 开头) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Url @Url.setter def Url(self, Url): self._Url = Url def _deserialize(self, params): self._Url = params.get("Url") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class LogoParam(AbstractModel): """logo参数 """ def __init__(self): r""" :param _LogoUrl: 水印url :type LogoUrl: str :param _LogoImage: 水印base64,url和base64二选一传入 :type LogoImage: str :param _LogoRect: 水印图片位于融合结果图中的坐标,将按照坐标对标识图片进行位置和大小的拉伸匹配 :type LogoRect: :class:`tencentcloud.hunyuan.v20230901.models.LogoRect` """ self._LogoUrl = None self._LogoImage = None self._LogoRect = None @property def LogoUrl(self): """水印url :rtype: str """ return self._LogoUrl @LogoUrl.setter def LogoUrl(self, LogoUrl): self._LogoUrl = LogoUrl @property def LogoImage(self): """水印base64,url和base64二选一传入 :rtype: str """ return self._LogoImage @LogoImage.setter def LogoImage(self, LogoImage): self._LogoImage = LogoImage @property def LogoRect(self): """水印图片位于融合结果图中的坐标,将按照坐标对标识图片进行位置和大小的拉伸匹配 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.LogoRect` """ return self._LogoRect @LogoRect.setter def LogoRect(self, LogoRect): self._LogoRect = LogoRect def _deserialize(self, params): self._LogoUrl = params.get("LogoUrl") self._LogoImage = params.get("LogoImage") if params.get("LogoRect") is not None: self._LogoRect = LogoRect() self._LogoRect._deserialize(params.get("LogoRect")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class LogoRect(AbstractModel): """输入框 """ def __init__(self): r""" :param _X: 左上角X坐标 :type X: int :param _Y: 左上角Y坐标 :type Y: int :param _Width: 方框宽度 :type Width: int :param _Height: 方框高度 :type Height: int """ self._X = None self._Y = None self._Width = None self._Height = None @property def X(self): """左上角X坐标 :rtype: int """ return self._X @X.setter def X(self, X): self._X = X @property def Y(self): """左上角Y坐标 :rtype: int """ return self._Y @Y.setter def Y(self, Y): self._Y = Y @property def Width(self): """方框宽度 :rtype: int """ return self._Width @Width.setter def Width(self, Width): self._Width = Width @property def Height(self): """方框高度 :rtype: int """ return self._Height @Height.setter def Height(self, Height): self._Height = Height def _deserialize(self, params): self._X = params.get("X") self._Y = params.get("Y") self._Width = params.get("Width") self._Height = params.get("Height") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Message(AbstractModel): """会话内容 """ def __init__(self): r""" :param _Role: 角色,可选值包括 system、user、assistant、 tool。 :type Role: str :param _Content: 文本内容 :type Content: str :param _Contents: 多种类型内容(目前支持图片和文本),仅 hunyuan-vision 和 hunyuan-turbo-vision 模型支持 注意:此字段可能返回 null,表示取不到有效值。 :type Contents: list of Content :param _ToolCallId: 当role为tool时传入,标识具体的函数调用 注意:此字段可能返回 null,表示取不到有效值。 :type ToolCallId: str :param _ToolCalls: 模型生成的工具调用,仅 hunyuan-pro 或者 hunyuan-functioncall 模型支持 注意:此字段可能返回 null,表示取不到有效值。 :type ToolCalls: list of ToolCall :param _FileIDs: 文件标识符。单次最大 50 个文件。 注意:此字段可能返回 null,表示取不到有效值。 :type FileIDs: list of str """ self._Role = None self._Content = None self._Contents = None self._ToolCallId = None self._ToolCalls = None self._FileIDs = None @property def Role(self): """角色,可选值包括 system、user、assistant、 tool。 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """文本内容 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def Contents(self): """多种类型内容(目前支持图片和文本),仅 hunyuan-vision 和 hunyuan-turbo-vision 模型支持 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of Content """ return self._Contents @Contents.setter def Contents(self, Contents): self._Contents = Contents @property def ToolCallId(self): """当role为tool时传入,标识具体的函数调用 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._ToolCallId @ToolCallId.setter def ToolCallId(self, ToolCallId): self._ToolCallId = ToolCallId @property def ToolCalls(self): """模型生成的工具调用,仅 hunyuan-pro 或者 hunyuan-functioncall 模型支持 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of ToolCall """ return self._ToolCalls @ToolCalls.setter def ToolCalls(self, ToolCalls): self._ToolCalls = ToolCalls @property def FileIDs(self): """文件标识符。单次最大 50 个文件。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of str """ return self._FileIDs @FileIDs.setter def FileIDs(self, FileIDs): self._FileIDs = FileIDs def _deserialize(self, params): self._Role = params.get("Role") self._Content = params.get("Content") if params.get("Contents") is not None: self._Contents = [] for item in params.get("Contents"): obj = Content() obj._deserialize(item) self._Contents.append(obj) self._ToolCallId = params.get("ToolCallId") if params.get("ToolCalls") is not None: self._ToolCalls = [] for item in params.get("ToolCalls"): obj = ToolCall() obj._deserialize(item) self._ToolCalls.append(obj) self._FileIDs = params.get("FileIDs") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Mindmap(AbstractModel): """脑图 """ def __init__(self): r""" :param _ThumbUrl: 脑图缩略图链接 注意:此字段可能返回 null,表示取不到有效值。 :type ThumbUrl: str :param _Url: 脑图图片链接 注意:此字段可能返回 null,表示取不到有效值。 :type Url: str """ self._ThumbUrl = None self._Url = None @property def ThumbUrl(self): """脑图缩略图链接 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._ThumbUrl @ThumbUrl.setter def ThumbUrl(self, ThumbUrl): self._ThumbUrl = ThumbUrl @property def Url(self): """脑图图片链接 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Url @Url.setter def Url(self, Url): self._Url = Url def _deserialize(self, params): self._ThumbUrl = params.get("ThumbUrl") self._Url = params.get("Url") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Multimedia(AbstractModel): """多媒体详情 """ def __init__(self): r""" :param _Type: 多媒体类型,可选值包括 image、music、album、playlist。 说明: 1. image:图片;music:单曲,类型为单曲时,会返回详细歌手和歌曲信息;album:专辑;playlist:歌单。 2. 当 type 为 music、album、playlist 时,需要配合 [QQ音乐SDK](https://developer.y.qq.com/) 使用。 :type Type: str :param _Url: 多媒体地址。 说明: 1. type 为 image 时,地址为图片的预览地址;其他类型时,地址为封面图地址。 :type Url: str :param _JumpUrl: 多媒体详情地址。 说明: 1. 仅 type 为 image 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :type JumpUrl: str :param _Title: 名称。 说明: 1. type 为 image 时,该字段为空。 注意:此字段可能返回 null,表示取不到有效值。 :type Title: str :param _Desc: 描述。 注意:此字段可能返回 null,表示取不到有效值。 :type Desc: str :param _Singer: 歌手名称。 说明: 1. 仅 type 为 music 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :type Singer: str :param _Ext: 歌曲详情。 说明: 1. 仅 type 为 music 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :type Ext: :class:`tencentcloud.hunyuan.v20230901.models.SongExt` """ self._Type = None self._Url = None self._JumpUrl = None self._Title = None self._Desc = None self._Singer = None self._Ext = None @property def Type(self): """多媒体类型,可选值包括 image、music、album、playlist。 说明: 1. image:图片;music:单曲,类型为单曲时,会返回详细歌手和歌曲信息;album:专辑;playlist:歌单。 2. 当 type 为 music、album、playlist 时,需要配合 [QQ音乐SDK](https://developer.y.qq.com/) 使用。 :rtype: str """ return self._Type @Type.setter def Type(self, Type): self._Type = Type @property def Url(self): """多媒体地址。 说明: 1. type 为 image 时,地址为图片的预览地址;其他类型时,地址为封面图地址。 :rtype: str """ return self._Url @Url.setter def Url(self, Url): self._Url = Url @property def JumpUrl(self): """多媒体详情地址。 说明: 1. 仅 type 为 image 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._JumpUrl @JumpUrl.setter def JumpUrl(self, JumpUrl): self._JumpUrl = JumpUrl @property def Title(self): """名称。 说明: 1. type 为 image 时,该字段为空。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Title @Title.setter def Title(self, Title): self._Title = Title @property def Desc(self): """描述。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Desc @Desc.setter def Desc(self, Desc): self._Desc = Desc @property def Singer(self): """歌手名称。 说明: 1. 仅 type 为 music 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Singer @Singer.setter def Singer(self, Singer): self._Singer = Singer @property def Ext(self): """歌曲详情。 说明: 1. 仅 type 为 music 时,该字段有值。 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.SongExt` """ return self._Ext @Ext.setter def Ext(self, Ext): self._Ext = Ext def _deserialize(self, params): self._Type = params.get("Type") self._Url = params.get("Url") self._JumpUrl = params.get("JumpUrl") self._Title = params.get("Title") self._Desc = params.get("Desc") self._Singer = params.get("Singer") if params.get("Ext") is not None: self._Ext = SongExt() self._Ext._deserialize(params.get("Ext")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class QueryHunyuanImageChatJobRequest(AbstractModel): """QueryHunyuanImageChatJob请求参数结构体 """ def __init__(self): r""" :param _JobId: 任务 ID。 :type JobId: str """ self._JobId = None @property def JobId(self): """任务 ID。 :rtype: str """ return self._JobId @JobId.setter def JobId(self, JobId): self._JobId = JobId def _deserialize(self, params): self._JobId = params.get("JobId") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class QueryHunyuanImageChatJobResponse(AbstractModel): """QueryHunyuanImageChatJob返回参数结构体 """ def __init__(self): r""" :param _JobStatusCode: 当前任务状态码: 1:等待中、2:运行中、4:处理失败、5:处理完成。 :type JobStatusCode: str :param _JobStatusMsg: 当前任务状态:排队中、处理中、处理失败或者处理完成。 :type JobStatusMsg: str :param _JobErrorCode: 任务处理失败错误码。 :type JobErrorCode: str :param _JobErrorMsg: 任务处理失败错误信息。 :type JobErrorMsg: str :param _ChatId: 本轮对话的 ChatId,ChatId 用于唯一标识一轮对话。 一个对话组中,最多支持进行100轮对话。 每轮对话数据有效期为7天,到期后 ChatId 失效,有效期内的历史对话数据可通过 History 查询,如有长期使用需求请及时保存输入输出数据。 :type ChatId: str :param _ResultImage: 生成图 URL 列表,有效期7天,请及时保存。 :type ResultImage: list of str :param _ResultDetails: 结果 detail 数组,Success 代表成功。 :type ResultDetails: list of str :param _History: 本轮对话前置的历史对话数据(不含生成图)。 :type History: list of History :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._JobStatusCode = None self._JobStatusMsg = None self._JobErrorCode = None self._JobErrorMsg = None self._ChatId = None self._ResultImage = None self._ResultDetails = None self._History = None self._RequestId = None @property def JobStatusCode(self): """当前任务状态码: 1:等待中、2:运行中、4:处理失败、5:处理完成。 :rtype: str """ return self._JobStatusCode @JobStatusCode.setter def JobStatusCode(self, JobStatusCode): self._JobStatusCode = JobStatusCode @property def JobStatusMsg(self): """当前任务状态:排队中、处理中、处理失败或者处理完成。 :rtype: str """ return self._JobStatusMsg @JobStatusMsg.setter def JobStatusMsg(self, JobStatusMsg): self._JobStatusMsg = JobStatusMsg @property def JobErrorCode(self): """任务处理失败错误码。 :rtype: str """ return self._JobErrorCode @JobErrorCode.setter def JobErrorCode(self, JobErrorCode): self._JobErrorCode = JobErrorCode @property def JobErrorMsg(self): """任务处理失败错误信息。 :rtype: str """ return self._JobErrorMsg @JobErrorMsg.setter def JobErrorMsg(self, JobErrorMsg): self._JobErrorMsg = JobErrorMsg @property def ChatId(self): """本轮对话的 ChatId,ChatId 用于唯一标识一轮对话。 一个对话组中,最多支持进行100轮对话。 每轮对话数据有效期为7天,到期后 ChatId 失效,有效期内的历史对话数据可通过 History 查询,如有长期使用需求请及时保存输入输出数据。 :rtype: str """ return self._ChatId @ChatId.setter def ChatId(self, ChatId): self._ChatId = ChatId @property def ResultImage(self): """生成图 URL 列表,有效期7天,请及时保存。 :rtype: list of str """ return self._ResultImage @ResultImage.setter def ResultImage(self, ResultImage): self._ResultImage = ResultImage @property def ResultDetails(self): """结果 detail 数组,Success 代表成功。 :rtype: list of str """ return self._ResultDetails @ResultDetails.setter def ResultDetails(self, ResultDetails): self._ResultDetails = ResultDetails @property def History(self): """本轮对话前置的历史对话数据(不含生成图)。 :rtype: list of History """ return self._History @History.setter def History(self, History): self._History = History @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._JobStatusCode = params.get("JobStatusCode") self._JobStatusMsg = params.get("JobStatusMsg") self._JobErrorCode = params.get("JobErrorCode") self._JobErrorMsg = params.get("JobErrorMsg") self._ChatId = params.get("ChatId") self._ResultImage = params.get("ResultImage") self._ResultDetails = params.get("ResultDetails") if params.get("History") is not None: self._History = [] for item in params.get("History"): obj = History() obj._deserialize(item) self._History.append(obj) self._RequestId = params.get("RequestId") class QueryHunyuanImageJobRequest(AbstractModel): """QueryHunyuanImageJob请求参数结构体 """ def __init__(self): r""" :param _JobId: 任务 ID。 :type JobId: str """ self._JobId = None @property def JobId(self): """任务 ID。 :rtype: str """ return self._JobId @JobId.setter def JobId(self, JobId): self._JobId = JobId def _deserialize(self, params): self._JobId = params.get("JobId") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class QueryHunyuanImageJobResponse(AbstractModel): """QueryHunyuanImageJob返回参数结构体 """ def __init__(self): r""" :param _JobStatusCode: 当前任务状态码: 1:等待中、2:运行中、4:处理失败、5:处理完成。 :type JobStatusCode: str :param _JobStatusMsg: 当前任务状态:排队中、处理中、处理失败或者处理完成。 :type JobStatusMsg: str :param _JobErrorCode: 任务处理失败错误码。 :type JobErrorCode: str :param _JobErrorMsg: 任务处理失败错误信息。 :type JobErrorMsg: str :param _ResultImage: 生成图 URL 列表,有效期1小时,请及时保存。 :type ResultImage: list of str :param _ResultDetails: 结果 detail 数组,Success 代表成功。 :type ResultDetails: list of str :param _RevisedPrompt: 对应 SubmitHunyuanImageJob 接口中 Revise 参数。开启扩写时,返回扩写后的 prompt 文本。 如果关闭扩写,将直接返回原始输入的 prompt。 :type RevisedPrompt: list of str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._JobStatusCode = None self._JobStatusMsg = None self._JobErrorCode = None self._JobErrorMsg = None self._ResultImage = None self._ResultDetails = None self._RevisedPrompt = None self._RequestId = None @property def JobStatusCode(self): """当前任务状态码: 1:等待中、2:运行中、4:处理失败、5:处理完成。 :rtype: str """ return self._JobStatusCode @JobStatusCode.setter def JobStatusCode(self, JobStatusCode): self._JobStatusCode = JobStatusCode @property def JobStatusMsg(self): """当前任务状态:排队中、处理中、处理失败或者处理完成。 :rtype: str """ return self._JobStatusMsg @JobStatusMsg.setter def JobStatusMsg(self, JobStatusMsg): self._JobStatusMsg = JobStatusMsg @property def JobErrorCode(self): """任务处理失败错误码。 :rtype: str """ return self._JobErrorCode @JobErrorCode.setter def JobErrorCode(self, JobErrorCode): self._JobErrorCode = JobErrorCode @property def JobErrorMsg(self): """任务处理失败错误信息。 :rtype: str """ return self._JobErrorMsg @JobErrorMsg.setter def JobErrorMsg(self, JobErrorMsg): self._JobErrorMsg = JobErrorMsg @property def ResultImage(self): """生成图 URL 列表,有效期1小时,请及时保存。 :rtype: list of str """ return self._ResultImage @ResultImage.setter def ResultImage(self, ResultImage): self._ResultImage = ResultImage @property def ResultDetails(self): """结果 detail 数组,Success 代表成功。 :rtype: list of str """ return self._ResultDetails @ResultDetails.setter def ResultDetails(self, ResultDetails): self._ResultDetails = ResultDetails @property def RevisedPrompt(self): """对应 SubmitHunyuanImageJob 接口中 Revise 参数。开启扩写时,返回扩写后的 prompt 文本。 如果关闭扩写,将直接返回原始输入的 prompt。 :rtype: list of str """ return self._RevisedPrompt @RevisedPrompt.setter def RevisedPrompt(self, RevisedPrompt): self._RevisedPrompt = RevisedPrompt @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._JobStatusCode = params.get("JobStatusCode") self._JobStatusMsg = params.get("JobStatusMsg") self._JobErrorCode = params.get("JobErrorCode") self._JobErrorMsg = params.get("JobErrorMsg") self._ResultImage = params.get("ResultImage") self._ResultDetails = params.get("ResultDetails") self._RevisedPrompt = params.get("RevisedPrompt") self._RequestId = params.get("RequestId") class Reference(AbstractModel): """翻译对话参考示例 """ def __init__(self): r""" :param _Type: 翻译文本类型,枚举"sentence"表示句子, "term"表示术语 :type Type: str :param _Text: 原文 :type Text: str :param _Translation: 译文 :type Translation: str """ self._Type = None self._Text = None self._Translation = None @property def Type(self): """翻译文本类型,枚举"sentence"表示句子, "term"表示术语 :rtype: str """ return self._Type @Type.setter def Type(self, Type): self._Type = Type @property def Text(self): """原文 :rtype: str """ return self._Text @Text.setter def Text(self, Text): self._Text = Text @property def Translation(self): """译文 :rtype: str """ return self._Translation @Translation.setter def Translation(self, Translation): self._Translation = Translation def _deserialize(self, params): self._Type = params.get("Type") self._Text = params.get("Text") self._Translation = params.get("Translation") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class RelevantEntity(AbstractModel): """相关组织及人物 """ def __init__(self): r""" :param _Name: 相关组织及人物名称 注意:此字段可能返回 null,表示取不到有效值。 :type Name: str :param _Content: 相关组织及人物内容 注意:此字段可能返回 null,表示取不到有效值。 :type Content: str :param _Reference: 相关事件引用文章标号 注意:此字段可能返回 null,表示取不到有效值。 :type Reference: list of int """ self._Name = None self._Content = None self._Reference = None @property def Name(self): """相关组织及人物名称 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Name @Name.setter def Name(self, Name): self._Name = Name @property def Content(self): """相关组织及人物内容 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def Reference(self): """相关事件引用文章标号 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of int """ return self._Reference @Reference.setter def Reference(self, Reference): self._Reference = Reference def _deserialize(self, params): self._Name = params.get("Name") self._Content = params.get("Content") self._Reference = params.get("Reference") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class RelevantEvent(AbstractModel): """相关事件 """ def __init__(self): r""" :param _Title: 相关事件标题 注意:此字段可能返回 null,表示取不到有效值。 :type Title: str :param _Content: 相关事件内容 注意:此字段可能返回 null,表示取不到有效值。 :type Content: str :param _Datetime: 相关事件时间 注意:此字段可能返回 null,表示取不到有效值。 :type Datetime: str :param _Reference: 相关事件引用文章标号 注意:此字段可能返回 null,表示取不到有效值。 :type Reference: list of int """ self._Title = None self._Content = None self._Datetime = None self._Reference = None @property def Title(self): """相关事件标题 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Title @Title.setter def Title(self, Title): self._Title = Title @property def Content(self): """相关事件内容 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def Datetime(self): """相关事件时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Datetime @Datetime.setter def Datetime(self, Datetime): self._Datetime = Datetime @property def Reference(self): """相关事件引用文章标号 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of int """ return self._Reference @Reference.setter def Reference(self, Reference): self._Reference = Reference def _deserialize(self, params): self._Title = params.get("Title") self._Content = params.get("Content") self._Datetime = params.get("Datetime") self._Reference = params.get("Reference") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Replace(AbstractModel): """多媒体占位符替换信息 """ def __init__(self): r""" :param _Id: 占位符序号 :type Id: str :param _Multimedia: 多媒体详情 :type Multimedia: list of Multimedia """ self._Id = None self._Multimedia = None @property def Id(self): """占位符序号 :rtype: str """ return self._Id @Id.setter def Id(self, Id): self._Id = Id @property def Multimedia(self): """多媒体详情 :rtype: list of Multimedia """ return self._Multimedia @Multimedia.setter def Multimedia(self, Multimedia): self._Multimedia = Multimedia def _deserialize(self, params): self._Id = params.get("Id") if params.get("Multimedia") is not None: self._Multimedia = [] for item in params.get("Multimedia"): obj = Multimedia() obj._deserialize(item) self._Multimedia.append(obj) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class RunThreadRequest(AbstractModel): """RunThread请求参数结构体 """ def __init__(self): r""" :param _ThreadID: 会话 ID :type ThreadID: str :param _AssistantID: 助手 ID(目前未使用,留空) :type AssistantID: str :param _Model: 模型名称,可选值包括 hunyuan-lite、hunyuan-standard、hunyuan-standard-256K、hunyuan-pro、 hunyuan-code、 hunyuan-role、 hunyuan-functioncall、 hunyuan-vision、 hunyuan-turbo。各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。注意:不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :type Model: str :param _AdditionalMessages: 附加消息 :type AdditionalMessages: list of ThreadAdditionalMessage :param _Temperature: 说明:1. 影响模型输出多样性,模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。2. 取值区间为 [0.0, 2.0]。较高的数值会使输出更加多样化和不可预测,而较低的数值会使其更加集中和确定。 :type Temperature: float :param _TopP: 说明:1. 影响输出文本的多样性。模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。2. 取值区间为 [0.0, 1.0]。取值越大,生成文本的多样性越强。 :type TopP: float :param _Stream: 是否流式输出,当前只允许 true :type Stream: bool :param _MaxPromptTokens: 运行过程中可使用的 token 最大数量。 :type MaxPromptTokens: int :param _MaxCompletionTokens: 运行过程中可使用的完成 token 的最大数量。 :type MaxCompletionTokens: int :param _Tools: 可调用的工具列表,仅对 hunyuan-pro、hunyuan-turbo、hunyuan-functioncall 模型生效。 :type Tools: list of Tool :param _ToolChoice: 工具使用选项,可选值包括 none、auto、custom。说明:1. 仅对 hunyuan-pro、hunyuan-turbo、hunyuan-functioncall 模型生效。2. none:不调用工具;auto:模型自行选择生成回复或调用工具;custom:强制模型调用指定的工具。3. 未设置时,默认值为auto :type ToolChoice: str """ self._ThreadID = None self._AssistantID = None self._Model = None self._AdditionalMessages = None self._Temperature = None self._TopP = None self._Stream = None self._MaxPromptTokens = None self._MaxCompletionTokens = None self._Tools = None self._ToolChoice = None @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID @property def AssistantID(self): """助手 ID(目前未使用,留空) :rtype: str """ return self._AssistantID @AssistantID.setter def AssistantID(self, AssistantID): self._AssistantID = AssistantID @property def Model(self): """模型名称,可选值包括 hunyuan-lite、hunyuan-standard、hunyuan-standard-256K、hunyuan-pro、 hunyuan-code、 hunyuan-role、 hunyuan-functioncall、 hunyuan-vision、 hunyuan-turbo。各模型介绍请阅读 [产品概述](https://cloud.tencent.com/document/product/1729/104753) 中的说明。注意:不同的模型计费不同,请根据 [购买指南](https://cloud.tencent.com/document/product/1729/97731) 按需调用。 :rtype: str """ return self._Model @Model.setter def Model(self, Model): self._Model = Model @property def AdditionalMessages(self): """附加消息 :rtype: list of ThreadAdditionalMessage """ return self._AdditionalMessages @AdditionalMessages.setter def AdditionalMessages(self, AdditionalMessages): self._AdditionalMessages = AdditionalMessages @property def Temperature(self): """说明:1. 影响模型输出多样性,模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。2. 取值区间为 [0.0, 2.0]。较高的数值会使输出更加多样化和不可预测,而较低的数值会使其更加集中和确定。 :rtype: float """ return self._Temperature @Temperature.setter def Temperature(self, Temperature): self._Temperature = Temperature @property def TopP(self): """说明:1. 影响输出文本的多样性。模型已有默认参数,不传值时使用各模型推荐值,不推荐用户修改。2. 取值区间为 [0.0, 1.0]。取值越大,生成文本的多样性越强。 :rtype: float """ return self._TopP @TopP.setter def TopP(self, TopP): self._TopP = TopP @property def Stream(self): """是否流式输出,当前只允许 true :rtype: bool """ return self._Stream @Stream.setter def Stream(self, Stream): self._Stream = Stream @property def MaxPromptTokens(self): """运行过程中可使用的 token 最大数量。 :rtype: int """ return self._MaxPromptTokens @MaxPromptTokens.setter def MaxPromptTokens(self, MaxPromptTokens): self._MaxPromptTokens = MaxPromptTokens @property def MaxCompletionTokens(self): """运行过程中可使用的完成 token 的最大数量。 :rtype: int """ return self._MaxCompletionTokens @MaxCompletionTokens.setter def MaxCompletionTokens(self, MaxCompletionTokens): self._MaxCompletionTokens = MaxCompletionTokens @property def Tools(self): """可调用的工具列表,仅对 hunyuan-pro、hunyuan-turbo、hunyuan-functioncall 模型生效。 :rtype: list of Tool """ return self._Tools @Tools.setter def Tools(self, Tools): self._Tools = Tools @property def ToolChoice(self): """工具使用选项,可选值包括 none、auto、custom。说明:1. 仅对 hunyuan-pro、hunyuan-turbo、hunyuan-functioncall 模型生效。2. none:不调用工具;auto:模型自行选择生成回复或调用工具;custom:强制模型调用指定的工具。3. 未设置时,默认值为auto :rtype: str """ return self._ToolChoice @ToolChoice.setter def ToolChoice(self, ToolChoice): self._ToolChoice = ToolChoice def _deserialize(self, params): self._ThreadID = params.get("ThreadID") self._AssistantID = params.get("AssistantID") self._Model = params.get("Model") if params.get("AdditionalMessages") is not None: self._AdditionalMessages = [] for item in params.get("AdditionalMessages"): obj = ThreadAdditionalMessage() obj._deserialize(item) self._AdditionalMessages.append(obj) self._Temperature = params.get("Temperature") self._TopP = params.get("TopP") self._Stream = params.get("Stream") self._MaxPromptTokens = params.get("MaxPromptTokens") self._MaxCompletionTokens = params.get("MaxCompletionTokens") if params.get("Tools") is not None: self._Tools = [] for item in params.get("Tools"): obj = Tool() obj._deserialize(item) self._Tools.append(obj) self._ToolChoice = params.get("ToolChoice") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class RunThreadResponse(AbstractModel): """RunThread返回参数结构体 """ def __init__(self): r""" :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :type RequestId: str """ self._RequestId = None @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。本接口为流式响应接口,当请求成功时,RequestId 会被放在 HTTP 响应的 Header "X-TC-RequestId" 中。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._RequestId = params.get("RequestId") class SearchInfo(AbstractModel): """搜索结果信息 """ def __init__(self): r""" :param _SearchResults: 搜索引文信息 注意:此字段可能返回 null,表示取不到有效值。 :type SearchResults: list of SearchResult :param _Mindmap: 脑图(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回) 注意:此字段可能返回 null,表示取不到有效值。 :type Mindmap: :class:`tencentcloud.hunyuan.v20230901.models.Mindmap` :param _RelevantEvents: 相关事件(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :type RelevantEvents: list of RelevantEvent :param _RelevantEntities: 相关组织及人物(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :type RelevantEntities: list of RelevantEntity :param _Timeline: 时间线(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :type Timeline: list of Timeline :param _SupportDeepSearch: 是否命中搜索深度模式 注意:此字段可能返回 null,表示取不到有效值。 :type SupportDeepSearch: bool :param _Outline: 搜索回复大纲(深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :type Outline: list of str """ self._SearchResults = None self._Mindmap = None self._RelevantEvents = None self._RelevantEntities = None self._Timeline = None self._SupportDeepSearch = None self._Outline = None @property def SearchResults(self): """搜索引文信息 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of SearchResult """ return self._SearchResults @SearchResults.setter def SearchResults(self, SearchResults): self._SearchResults = SearchResults @property def Mindmap(self): """脑图(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.Mindmap` """ return self._Mindmap @Mindmap.setter def Mindmap(self, Mindmap): self._Mindmap = Mindmap @property def RelevantEvents(self): """相关事件(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of RelevantEvent """ return self._RelevantEvents @RelevantEvents.setter def RelevantEvents(self, RelevantEvents): self._RelevantEvents = RelevantEvents @property def RelevantEntities(self): """相关组织及人物(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of RelevantEntity """ return self._RelevantEntities @RelevantEntities.setter def RelevantEntities(self, RelevantEntities): self._RelevantEntities = RelevantEntities @property def Timeline(self): """时间线(回复中不一定存在,流式协议中,仅在最后一条流式数据中返回,深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of Timeline """ return self._Timeline @Timeline.setter def Timeline(self, Timeline): self._Timeline = Timeline @property def SupportDeepSearch(self): """是否命中搜索深度模式 注意:此字段可能返回 null,表示取不到有效值。 :rtype: bool """ return self._SupportDeepSearch @SupportDeepSearch.setter def SupportDeepSearch(self, SupportDeepSearch): self._SupportDeepSearch = SupportDeepSearch @property def Outline(self): """搜索回复大纲(深度模式下返回) 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of str """ return self._Outline @Outline.setter def Outline(self, Outline): self._Outline = Outline def _deserialize(self, params): if params.get("SearchResults") is not None: self._SearchResults = [] for item in params.get("SearchResults"): obj = SearchResult() obj._deserialize(item) self._SearchResults.append(obj) if params.get("Mindmap") is not None: self._Mindmap = Mindmap() self._Mindmap._deserialize(params.get("Mindmap")) if params.get("RelevantEvents") is not None: self._RelevantEvents = [] for item in params.get("RelevantEvents"): obj = RelevantEvent() obj._deserialize(item) self._RelevantEvents.append(obj) if params.get("RelevantEntities") is not None: self._RelevantEntities = [] for item in params.get("RelevantEntities"): obj = RelevantEntity() obj._deserialize(item) self._RelevantEntities.append(obj) if params.get("Timeline") is not None: self._Timeline = [] for item in params.get("Timeline"): obj = Timeline() obj._deserialize(item) self._Timeline.append(obj) self._SupportDeepSearch = params.get("SupportDeepSearch") self._Outline = params.get("Outline") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SearchResult(AbstractModel): """搜索引文信息 """ def __init__(self): r""" :param _Index: 搜索引文序号 注意:此字段可能返回 null,表示取不到有效值。 :type Index: int :param _Title: 搜索引文标题 注意:此字段可能返回 null,表示取不到有效值。 :type Title: str :param _Url: 搜索引文链接 注意:此字段可能返回 null,表示取不到有效值。 :type Url: str :param _Text: 搜索引文站点名 :type Text: str :param _Icon: 搜索引文图标 :type Icon: str """ self._Index = None self._Title = None self._Url = None self._Text = None self._Icon = None @property def Index(self): """搜索引文序号 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._Index @Index.setter def Index(self, Index): self._Index = Index @property def Title(self): """搜索引文标题 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Title @Title.setter def Title(self, Title): self._Title = Title @property def Url(self): """搜索引文链接 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Url @Url.setter def Url(self, Url): self._Url = Url @property def Text(self): """搜索引文站点名 :rtype: str """ return self._Text @Text.setter def Text(self, Text): self._Text = Text @property def Icon(self): """搜索引文图标 :rtype: str """ return self._Icon @Icon.setter def Icon(self, Icon): self._Icon = Icon def _deserialize(self, params): self._Index = params.get("Index") self._Title = params.get("Title") self._Url = params.get("Url") self._Text = params.get("Text") self._Icon = params.get("Icon") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SetPayModeRequest(AbstractModel): """SetPayMode请求参数结构体 """ def __init__(self): r""" :param _PayMode: 设置后付费状态,0:后付费打开;1:后付费关闭 :type PayMode: int """ self._PayMode = None @property def PayMode(self): """设置后付费状态,0:后付费打开;1:后付费关闭 :rtype: int """ return self._PayMode @PayMode.setter def PayMode(self, PayMode): self._PayMode = PayMode def _deserialize(self, params): self._PayMode = params.get("PayMode") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SetPayModeResponse(AbstractModel): """SetPayMode返回参数结构体 """ def __init__(self): r""" :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._RequestId = None @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._RequestId = params.get("RequestId") class SongExt(AbstractModel): """歌曲详情。具体含义参考 [QQ音乐SDK](https://developer.y.qq.com/) """ def __init__(self): r""" :param _SongId: 歌曲id :type SongId: int :param _SongMid: 歌曲mid :type SongMid: str :param _Vip: 歌曲是否为vip。1:vip歌曲; 0:普通歌曲。 :type Vip: int """ self._SongId = None self._SongMid = None self._Vip = None @property def SongId(self): """歌曲id :rtype: int """ return self._SongId @SongId.setter def SongId(self, SongId): self._SongId = SongId @property def SongMid(self): """歌曲mid :rtype: str """ return self._SongMid @SongMid.setter def SongMid(self, SongMid): self._SongMid = SongMid @property def Vip(self): """歌曲是否为vip。1:vip歌曲; 0:普通歌曲。 :rtype: int """ return self._Vip @Vip.setter def Vip(self, Vip): self._Vip = Vip def _deserialize(self, params): self._SongId = params.get("SongId") self._SongMid = params.get("SongMid") self._Vip = params.get("Vip") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SubmitHunyuanImageChatJobRequest(AbstractModel): """SubmitHunyuanImageChatJob请求参数结构体 """ def __init__(self): r""" :param _Prompt: 本轮对话的文本描述。 提交一个任务请求对应发起一轮生图对话,每轮对话中可输入一条 Prompt,生成一张图像,支持通过多轮输入 Prompt 来不断调整图像内容。 推荐使用中文,最多可传1024个 utf-8 字符。 输入示例: <li> 第一轮对话:一颗红色的苹果 </li> <li> 第二轮对话:将苹果改为绿色 </li> <li> 第三轮对话:苹果放在桌子上 </li> :type Prompt: str :param _ChatId: 上传上一轮对话的 ChatId,本轮对话将在指定的上一轮对话结果基础上继续生成图像。 如果不传代表新建一个对话组,重新开启一轮新的对话。 一个对话组中,最多支持进行100轮对话。 :type ChatId: str :param _LogoAdd: 为生成结果图添加显式水印标识的开关,默认为1。 1:添加。 0:不添加。 其他数值:默认按1处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :type LogoAdd: int :param _LogoParam: 标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :type LogoParam: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` """ self._Prompt = None self._ChatId = None self._LogoAdd = None self._LogoParam = None @property def Prompt(self): """本轮对话的文本描述。 提交一个任务请求对应发起一轮生图对话,每轮对话中可输入一条 Prompt,生成一张图像,支持通过多轮输入 Prompt 来不断调整图像内容。 推荐使用中文,最多可传1024个 utf-8 字符。 输入示例: <li> 第一轮对话:一颗红色的苹果 </li> <li> 第二轮对话:将苹果改为绿色 </li> <li> 第三轮对话:苹果放在桌子上 </li> :rtype: str """ return self._Prompt @Prompt.setter def Prompt(self, Prompt): self._Prompt = Prompt @property def ChatId(self): """上传上一轮对话的 ChatId,本轮对话将在指定的上一轮对话结果基础上继续生成图像。 如果不传代表新建一个对话组,重新开启一轮新的对话。 一个对话组中,最多支持进行100轮对话。 :rtype: str """ return self._ChatId @ChatId.setter def ChatId(self, ChatId): self._ChatId = ChatId @property def LogoAdd(self): """为生成结果图添加显式水印标识的开关,默认为1。 1:添加。 0:不添加。 其他数值:默认按1处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :rtype: int """ return self._LogoAdd @LogoAdd.setter def LogoAdd(self, LogoAdd): self._LogoAdd = LogoAdd @property def LogoParam(self): """标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` """ return self._LogoParam @LogoParam.setter def LogoParam(self, LogoParam): self._LogoParam = LogoParam def _deserialize(self, params): self._Prompt = params.get("Prompt") self._ChatId = params.get("ChatId") self._LogoAdd = params.get("LogoAdd") if params.get("LogoParam") is not None: self._LogoParam = LogoParam() self._LogoParam._deserialize(params.get("LogoParam")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SubmitHunyuanImageChatJobResponse(AbstractModel): """SubmitHunyuanImageChatJob返回参数结构体 """ def __init__(self): r""" :param _JobId: 任务 ID。 :type JobId: str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._JobId = None self._RequestId = None @property def JobId(self): """任务 ID。 :rtype: str """ return self._JobId @JobId.setter def JobId(self, JobId): self._JobId = JobId @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._JobId = params.get("JobId") self._RequestId = params.get("RequestId") class SubmitHunyuanImageJobRequest(AbstractModel): """SubmitHunyuanImageJob请求参数结构体 """ def __init__(self): r""" :param _Prompt: 文本描述。 算法将根据输入的文本智能生成与之相关的图像。 不能为空,推荐使用中文。最多可传1024个 utf-8 字符。 :type Prompt: str :param _NegativePrompt: 反向提示词。 推荐使用中文。最多可传1024个 utf-8 字符。 :type NegativePrompt: str :param _Style: 绘画风格。 请在 [混元生图风格列表](https://cloud.tencent.com/document/product/1729/105846) 中选择期望的风格,传入风格编号。 不传默认不指定风格。 :type Style: str :param _Resolution: 生成图分辨率。 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3),不传默认使用1024:1024。 :type Resolution: str :param _Num: 图片生成数量。 支持1 ~ 4张,默认生成1张。 :type Num: int :param _Seed: 随机种子,默认随机。 不传:随机种子生成。 正数:固定种子生成。 :type Seed: int :param _Clarity: 超分选项,默认不做超分,可选开启。 x2:2倍超分 x4:4倍超分 :type Clarity: str :param _Revise: prompt 扩写开关。1为开启,0为关闭,不传默认开启。 开启扩写后,将自动扩写原始输入的 prompt 并使用扩写后的 prompt 生成图片,返回生成图片结果时将一并返回扩写后的 prompt 文本。 如果关闭扩写,将直接使用原始输入的 prompt 生成图片。 建议开启,在多数场景下可提升生成图片效果、丰富生成图片细节。 :type Revise: int :param _LogoAdd: 为生成结果图添加显式水印标识的开关,默认为1。 1:添加。 0:不添加。 其他数值:默认按1处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :type LogoAdd: int :param _LogoParam: 标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :type LogoParam: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` """ self._Prompt = None self._NegativePrompt = None self._Style = None self._Resolution = None self._Num = None self._Seed = None self._Clarity = None self._Revise = None self._LogoAdd = None self._LogoParam = None @property def Prompt(self): """文本描述。 算法将根据输入的文本智能生成与之相关的图像。 不能为空,推荐使用中文。最多可传1024个 utf-8 字符。 :rtype: str """ return self._Prompt @Prompt.setter def Prompt(self, Prompt): self._Prompt = Prompt @property def NegativePrompt(self): """反向提示词。 推荐使用中文。最多可传1024个 utf-8 字符。 :rtype: str """ return self._NegativePrompt @NegativePrompt.setter def NegativePrompt(self, NegativePrompt): self._NegativePrompt = NegativePrompt @property def Style(self): """绘画风格。 请在 [混元生图风格列表](https://cloud.tencent.com/document/product/1729/105846) 中选择期望的风格,传入风格编号。 不传默认不指定风格。 :rtype: str """ return self._Style @Style.setter def Style(self, Style): self._Style = Style @property def Resolution(self): """生成图分辨率。 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3),不传默认使用1024:1024。 :rtype: str """ return self._Resolution @Resolution.setter def Resolution(self, Resolution): self._Resolution = Resolution @property def Num(self): """图片生成数量。 支持1 ~ 4张,默认生成1张。 :rtype: int """ return self._Num @Num.setter def Num(self, Num): self._Num = Num @property def Seed(self): """随机种子,默认随机。 不传:随机种子生成。 正数:固定种子生成。 :rtype: int """ return self._Seed @Seed.setter def Seed(self, Seed): self._Seed = Seed @property def Clarity(self): """超分选项,默认不做超分,可选开启。 x2:2倍超分 x4:4倍超分 :rtype: str """ return self._Clarity @Clarity.setter def Clarity(self, Clarity): self._Clarity = Clarity @property def Revise(self): """prompt 扩写开关。1为开启,0为关闭,不传默认开启。 开启扩写后,将自动扩写原始输入的 prompt 并使用扩写后的 prompt 生成图片,返回生成图片结果时将一并返回扩写后的 prompt 文本。 如果关闭扩写,将直接使用原始输入的 prompt 生成图片。 建议开启,在多数场景下可提升生成图片效果、丰富生成图片细节。 :rtype: int """ return self._Revise @Revise.setter def Revise(self, Revise): self._Revise = Revise @property def LogoAdd(self): """为生成结果图添加显式水印标识的开关,默认为1。 1:添加。 0:不添加。 其他数值:默认按1处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :rtype: int """ return self._LogoAdd @LogoAdd.setter def LogoAdd(self, LogoAdd): self._LogoAdd = LogoAdd @property def LogoParam(self): """标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` """ return self._LogoParam @LogoParam.setter def LogoParam(self, LogoParam): self._LogoParam = LogoParam def _deserialize(self, params): self._Prompt = params.get("Prompt") self._NegativePrompt = params.get("NegativePrompt") self._Style = params.get("Style") self._Resolution = params.get("Resolution") self._Num = params.get("Num") self._Seed = params.get("Seed") self._Clarity = params.get("Clarity") self._Revise = params.get("Revise") self._LogoAdd = params.get("LogoAdd") if params.get("LogoParam") is not None: self._LogoParam = LogoParam() self._LogoParam._deserialize(params.get("LogoParam")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class SubmitHunyuanImageJobResponse(AbstractModel): """SubmitHunyuanImageJob返回参数结构体 """ def __init__(self): r""" :param _JobId: 任务 ID。 :type JobId: str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._JobId = None self._RequestId = None @property def JobId(self): """任务 ID。 :rtype: str """ return self._JobId @JobId.setter def JobId(self, JobId): self._JobId = JobId @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._JobId = params.get("JobId") self._RequestId = params.get("RequestId") class TextToImageLiteRequest(AbstractModel): """TextToImageLite请求参数结构体 """ def __init__(self): r""" :param _Prompt: 文本描述。 算法将根据输入的文本智能生成与之相关的图像。建议详细描述画面主体、细节、场景等,文本描述越丰富,生成效果越精美。 不能为空,推荐使用中文。最多可传256个 utf-8 字符。 :type Prompt: str :param _NegativePrompt: 反向文本描述。 用于一定程度上从反面引导模型生成的走向,减少生成结果中出现描述内容的可能,但不能完全杜绝。 推荐使用中文。最多可传256个 utf-8 字符。 :type NegativePrompt: str :param _Style: 绘画风格。 请在 [文生图轻量版风格列表](https://cloud.tencent.com/document/product/1729/108992) 中选择期望的风格,传入风格编号。不传默认使用201(日系动漫风格)。 :type Style: str :param _Resolution: 生成图分辨率。 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3)、1080:1920(9:16)、1920:1080(16:9),不传默认使用768:768。 :type Resolution: str :param _LogoAdd: 为生成结果图添加标识的开关,默认为1。 1:添加标识。 0:不添加标识。 其他数值:默认按0处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :type LogoAdd: int :param _LogoParam: 标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :type LogoParam: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` :param _RspImgType: 返回图像方式(base64 或 url) ,二选一,默认为 base64。url 有效期为1小时。 :type RspImgType: str """ self._Prompt = None self._NegativePrompt = None self._Style = None self._Resolution = None self._LogoAdd = None self._LogoParam = None self._RspImgType = None @property def Prompt(self): """文本描述。 算法将根据输入的文本智能生成与之相关的图像。建议详细描述画面主体、细节、场景等,文本描述越丰富,生成效果越精美。 不能为空,推荐使用中文。最多可传256个 utf-8 字符。 :rtype: str """ return self._Prompt @Prompt.setter def Prompt(self, Prompt): self._Prompt = Prompt @property def NegativePrompt(self): """反向文本描述。 用于一定程度上从反面引导模型生成的走向,减少生成结果中出现描述内容的可能,但不能完全杜绝。 推荐使用中文。最多可传256个 utf-8 字符。 :rtype: str """ return self._NegativePrompt @NegativePrompt.setter def NegativePrompt(self, NegativePrompt): self._NegativePrompt = NegativePrompt @property def Style(self): """绘画风格。 请在 [文生图轻量版风格列表](https://cloud.tencent.com/document/product/1729/108992) 中选择期望的风格,传入风格编号。不传默认使用201(日系动漫风格)。 :rtype: str """ return self._Style @Style.setter def Style(self, Style): self._Style = Style @property def Resolution(self): """生成图分辨率。 支持生成以下分辨率的图片:768:768(1:1)、768:1024(3:4)、1024:768(4:3)、1024:1024(1:1)、720:1280(9:16)、1280:720(16:9)、768:1280(3:5)、1280:768(5:3)、1080:1920(9:16)、1920:1080(16:9),不传默认使用768:768。 :rtype: str """ return self._Resolution @Resolution.setter def Resolution(self, Resolution): self._Resolution = Resolution @property def LogoAdd(self): """为生成结果图添加标识的开关,默认为1。 1:添加标识。 0:不添加标识。 其他数值:默认按0处理。 建议您使用显著标识来提示结果图使用了 AI 绘画技术,是 AI 生成的图片。 :rtype: int """ return self._LogoAdd @LogoAdd.setter def LogoAdd(self, LogoAdd): self._LogoAdd = LogoAdd @property def LogoParam(self): """标识内容设置。 默认在生成结果图右下角添加“图片由 AI 生成”字样,您可根据自身需要替换为其他的标识图片。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.LogoParam` """ return self._LogoParam @LogoParam.setter def LogoParam(self, LogoParam): self._LogoParam = LogoParam @property def RspImgType(self): """返回图像方式(base64 或 url) ,二选一,默认为 base64。url 有效期为1小时。 :rtype: str """ return self._RspImgType @RspImgType.setter def RspImgType(self, RspImgType): self._RspImgType = RspImgType def _deserialize(self, params): self._Prompt = params.get("Prompt") self._NegativePrompt = params.get("NegativePrompt") self._Style = params.get("Style") self._Resolution = params.get("Resolution") self._LogoAdd = params.get("LogoAdd") if params.get("LogoParam") is not None: self._LogoParam = LogoParam() self._LogoParam._deserialize(params.get("LogoParam")) self._RspImgType = params.get("RspImgType") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class TextToImageLiteResponse(AbstractModel): """TextToImageLite返回参数结构体 """ def __init__(self): r""" :param _ResultImage: 根据入参 RspImgType 填入不同,返回不同的内容。 如果传入 base64 则返回生成图 Base64 编码。 如果传入 url 则返回的生成图 URL , 有效期1小时,请及时保存。 :type ResultImage: str :param _RequestId: 唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :type RequestId: str """ self._ResultImage = None self._RequestId = None @property def ResultImage(self): """根据入参 RspImgType 填入不同,返回不同的内容。 如果传入 base64 则返回生成图 Base64 编码。 如果传入 url 则返回的生成图 URL , 有效期1小时,请及时保存。 :rtype: str """ return self._ResultImage @ResultImage.setter def ResultImage(self, ResultImage): self._ResultImage = ResultImage @property def RequestId(self): """唯一请求 ID,由服务端生成,每次请求都会返回(若请求因其他原因未能抵达服务端,则该次请求不会获得 RequestId)。定位问题时需要提供该次请求的 RequestId。 :rtype: str """ return self._RequestId @RequestId.setter def RequestId(self, RequestId): self._RequestId = RequestId def _deserialize(self, params): self._ResultImage = params.get("ResultImage") self._RequestId = params.get("RequestId") class ThreadAdditionalMessage(AbstractModel): """会话额外消息 """ def __init__(self): r""" :param _Role: 角色 :type Role: str :param _Content: 内容 :type Content: str :param _Attachments: 附件 注意:此字段可能返回 null,表示取不到有效值。 :type Attachments: list of ThreadMessageAttachmentObject """ self._Role = None self._Content = None self._Attachments = None @property def Role(self): """角色 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """内容 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def Attachments(self): """附件 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of ThreadMessageAttachmentObject """ return self._Attachments @Attachments.setter def Attachments(self, Attachments): self._Attachments = Attachments def _deserialize(self, params): self._Role = params.get("Role") self._Content = params.get("Content") if params.get("Attachments") is not None: self._Attachments = [] for item in params.get("Attachments"): obj = ThreadMessageAttachmentObject() obj._deserialize(item) self._Attachments.append(obj) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ThreadMessage(AbstractModel): """会话消息 """ def __init__(self): r""" :param _ID: 消息 ID :type ID: str :param _Object: 对象类型 :type Object: str :param _CreatedAt: 创建时间 :type CreatedAt: int :param _ThreadID: 会话 ID :type ThreadID: str :param _Status: 状态,处理中 in_progress,已完成 completed,未完成 incomplete。 :type Status: str :param _InCompleteDetails: 未完成原因 注意:此字段可能返回 null,表示取不到有效值。 :type InCompleteDetails: :class:`tencentcloud.hunyuan.v20230901.models.ThreadMessageInCompleteDetailsObject` :param _CompletedAt: 完成时间 注意:此字段可能返回 null,表示取不到有效值。 :type CompletedAt: int :param _InCompleteAt: 未完成时间 注意:此字段可能返回 null,表示取不到有效值。 :type InCompleteAt: int :param _Role: 角色 :type Role: str :param _Content: 内容 :type Content: str :param _AssistantID: 助手 ID 注意:此字段可能返回 null,表示取不到有效值。 :type AssistantID: str :param _RunID: 运行 ID 注意:此字段可能返回 null,表示取不到有效值。 :type RunID: str :param _Attachments: 附件 注意:此字段可能返回 null,表示取不到有效值。 :type Attachments: list of ThreadMessageAttachmentObject """ self._ID = None self._Object = None self._CreatedAt = None self._ThreadID = None self._Status = None self._InCompleteDetails = None self._CompletedAt = None self._InCompleteAt = None self._Role = None self._Content = None self._AssistantID = None self._RunID = None self._Attachments = None @property def ID(self): """消息 ID :rtype: str """ return self._ID @ID.setter def ID(self, ID): self._ID = ID @property def Object(self): """对象类型 :rtype: str """ return self._Object @Object.setter def Object(self, Object): self._Object = Object @property def CreatedAt(self): """创建时间 :rtype: int """ return self._CreatedAt @CreatedAt.setter def CreatedAt(self, CreatedAt): self._CreatedAt = CreatedAt @property def ThreadID(self): """会话 ID :rtype: str """ return self._ThreadID @ThreadID.setter def ThreadID(self, ThreadID): self._ThreadID = ThreadID @property def Status(self): """状态,处理中 in_progress,已完成 completed,未完成 incomplete。 :rtype: str """ return self._Status @Status.setter def Status(self, Status): self._Status = Status @property def InCompleteDetails(self): """未完成原因 注意:此字段可能返回 null,表示取不到有效值。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ThreadMessageInCompleteDetailsObject` """ return self._InCompleteDetails @InCompleteDetails.setter def InCompleteDetails(self, InCompleteDetails): self._InCompleteDetails = InCompleteDetails @property def CompletedAt(self): """完成时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._CompletedAt @CompletedAt.setter def CompletedAt(self, CompletedAt): self._CompletedAt = CompletedAt @property def InCompleteAt(self): """未完成时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: int """ return self._InCompleteAt @InCompleteAt.setter def InCompleteAt(self, InCompleteAt): self._InCompleteAt = InCompleteAt @property def Role(self): """角色 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """内容 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content @property def AssistantID(self): """助手 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._AssistantID @AssistantID.setter def AssistantID(self, AssistantID): self._AssistantID = AssistantID @property def RunID(self): """运行 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._RunID @RunID.setter def RunID(self, RunID): self._RunID = RunID @property def Attachments(self): """附件 注意:此字段可能返回 null,表示取不到有效值。 :rtype: list of ThreadMessageAttachmentObject """ return self._Attachments @Attachments.setter def Attachments(self, Attachments): self._Attachments = Attachments def _deserialize(self, params): self._ID = params.get("ID") self._Object = params.get("Object") self._CreatedAt = params.get("CreatedAt") self._ThreadID = params.get("ThreadID") self._Status = params.get("Status") if params.get("InCompleteDetails") is not None: self._InCompleteDetails = ThreadMessageInCompleteDetailsObject() self._InCompleteDetails._deserialize(params.get("InCompleteDetails")) self._CompletedAt = params.get("CompletedAt") self._InCompleteAt = params.get("InCompleteAt") self._Role = params.get("Role") self._Content = params.get("Content") self._AssistantID = params.get("AssistantID") self._RunID = params.get("RunID") if params.get("Attachments") is not None: self._Attachments = [] for item in params.get("Attachments"): obj = ThreadMessageAttachmentObject() obj._deserialize(item) self._Attachments.append(obj) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ThreadMessageAttachmentObject(AbstractModel): """会话消息附件 """ def __init__(self): r""" :param _FileID: 文件 ID 注意:此字段可能返回 null,表示取不到有效值。 :type FileID: str """ self._FileID = None @property def FileID(self): """文件 ID 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._FileID @FileID.setter def FileID(self, FileID): self._FileID = FileID def _deserialize(self, params): self._FileID = params.get("FileID") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ThreadMessageInCompleteDetailsObject(AbstractModel): """会话消息未完成原因 """ def __init__(self): r""" :param _Reason: 会话消息未完成原因 :type Reason: str """ self._Reason = None @property def Reason(self): """会话消息未完成原因 :rtype: str """ return self._Reason @Reason.setter def Reason(self, Reason): self._Reason = Reason def _deserialize(self, params): self._Reason = params.get("Reason") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ThreadToolResources(AbstractModel): """在会话中提供给助手工具的一系列资源。不同类型的工具会有各自对应的资源。比如代码解释器需要一个文件 ID 的列表,而文件搜索工具则需要一个向量存储 ID 的列表。 """ def __init__(self): r""" :param _CodeInterpreter: 文件 ID 列表 :type CodeInterpreter: list of str :param _VectorStoreIDs: 向量存储 ID 列表 :type VectorStoreIDs: list of str """ self._CodeInterpreter = None self._VectorStoreIDs = None @property def CodeInterpreter(self): """文件 ID 列表 :rtype: list of str """ return self._CodeInterpreter @CodeInterpreter.setter def CodeInterpreter(self, CodeInterpreter): self._CodeInterpreter = CodeInterpreter @property def VectorStoreIDs(self): """向量存储 ID 列表 :rtype: list of str """ return self._VectorStoreIDs @VectorStoreIDs.setter def VectorStoreIDs(self, VectorStoreIDs): self._VectorStoreIDs = VectorStoreIDs def _deserialize(self, params): self._CodeInterpreter = params.get("CodeInterpreter") self._VectorStoreIDs = params.get("VectorStoreIDs") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Timeline(AbstractModel): """时间线 """ def __init__(self): r""" :param _Title: 标题 注意:此字段可能返回 null,表示取不到有效值。 :type Title: str :param _Datetime: 时间 注意:此字段可能返回 null,表示取不到有效值。 :type Datetime: str :param _Url: 相关网页链接 注意:此字段可能返回 null,表示取不到有效值。 :type Url: str """ self._Title = None self._Datetime = None self._Url = None @property def Title(self): """标题 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Title @Title.setter def Title(self, Title): self._Title = Title @property def Datetime(self): """时间 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Datetime @Datetime.setter def Datetime(self, Datetime): self._Datetime = Datetime @property def Url(self): """相关网页链接 注意:此字段可能返回 null,表示取不到有效值。 :rtype: str """ return self._Url @Url.setter def Url(self, Url): self._Url = Url def _deserialize(self, params): self._Title = params.get("Title") self._Datetime = params.get("Datetime") self._Url = params.get("Url") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Tool(AbstractModel): """用户指定模型使用的工具 """ def __init__(self): r""" :param _Type: 工具类型,当前只支持function :type Type: str :param _Function: 具体要调用的function :type Function: :class:`tencentcloud.hunyuan.v20230901.models.ToolFunction` """ self._Type = None self._Function = None @property def Type(self): """工具类型,当前只支持function :rtype: str """ return self._Type @Type.setter def Type(self, Type): self._Type = Type @property def Function(self): """具体要调用的function :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ToolFunction` """ return self._Function @Function.setter def Function(self, Function): self._Function = Function def _deserialize(self, params): self._Type = params.get("Type") if params.get("Function") is not None: self._Function = ToolFunction() self._Function._deserialize(params.get("Function")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ToolCall(AbstractModel): """模型生成的工具调用 """ def __init__(self): r""" :param _Id: 工具调用id :type Id: str :param _Type: 工具调用类型,当前只支持function :type Type: str :param _Function: 具体的function调用 :type Function: :class:`tencentcloud.hunyuan.v20230901.models.ToolCallFunction` :param _Index: 索引值 :type Index: int """ self._Id = None self._Type = None self._Function = None self._Index = None @property def Id(self): """工具调用id :rtype: str """ return self._Id @Id.setter def Id(self, Id): self._Id = Id @property def Type(self): """工具调用类型,当前只支持function :rtype: str """ return self._Type @Type.setter def Type(self, Type): self._Type = Type @property def Function(self): """具体的function调用 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.ToolCallFunction` """ return self._Function @Function.setter def Function(self, Function): self._Function = Function @property def Index(self): """索引值 :rtype: int """ return self._Index @Index.setter def Index(self, Index): self._Index = Index def _deserialize(self, params): self._Id = params.get("Id") self._Type = params.get("Type") if params.get("Function") is not None: self._Function = ToolCallFunction() self._Function._deserialize(params.get("Function")) self._Index = params.get("Index") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ToolCallFunction(AbstractModel): """具体的function调用 """ def __init__(self): r""" :param _Name: function名称 :type Name: str :param _Arguments: function参数,一般为json字符串 :type Arguments: str """ self._Name = None self._Arguments = None @property def Name(self): """function名称 :rtype: str """ return self._Name @Name.setter def Name(self, Name): self._Name = Name @property def Arguments(self): """function参数,一般为json字符串 :rtype: str """ return self._Arguments @Arguments.setter def Arguments(self, Arguments): self._Arguments = Arguments def _deserialize(self, params): self._Name = params.get("Name") self._Arguments = params.get("Arguments") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class ToolFunction(AbstractModel): """function定义 """ def __init__(self): r""" :param _Name: function名称,只能包含a-z,A-Z,0-9,\_或- :type Name: str :param _Parameters: function参数,一般为json字符串 :type Parameters: str :param _Description: function的简单描述 :type Description: str """ self._Name = None self._Parameters = None self._Description = None @property def Name(self): """function名称,只能包含a-z,A-Z,0-9,\_或- :rtype: str """ return self._Name @Name.setter def Name(self, Name): self._Name = Name @property def Parameters(self): """function参数,一般为json字符串 :rtype: str """ return self._Parameters @Parameters.setter def Parameters(self, Parameters): self._Parameters = Parameters @property def Description(self): """function的简单描述 :rtype: str """ return self._Description @Description.setter def Description(self, Description): self._Description = Description def _deserialize(self, params): self._Name = params.get("Name") self._Parameters = params.get("Parameters") self._Description = params.get("Description") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class TranslationChoice(AbstractModel): """翻译接口返回的回复,支持多个 """ def __init__(self): r""" :param _FinishReason: 结束标志位,可能为 stop、 sensitive。 stop 表示输出正常结束。 sensitive 只在开启流式输出审核时会出现,表示安全审核未通过。 :type FinishReason: str :param _Index: 索引值,流式调用时使用该字段。 :type Index: int :param _Delta: 增量返回值,流式调用时使用该字段。 :type Delta: :class:`tencentcloud.hunyuan.v20230901.models.TranslationDelta` :param _Message: 返回值,非流式调用时使用该字段。 :type Message: :class:`tencentcloud.hunyuan.v20230901.models.TranslationMessage` """ self._FinishReason = None self._Index = None self._Delta = None self._Message = None @property def FinishReason(self): """结束标志位,可能为 stop、 sensitive。 stop 表示输出正常结束。 sensitive 只在开启流式输出审核时会出现,表示安全审核未通过。 :rtype: str """ return self._FinishReason @FinishReason.setter def FinishReason(self, FinishReason): self._FinishReason = FinishReason @property def Index(self): """索引值,流式调用时使用该字段。 :rtype: int """ return self._Index @Index.setter def Index(self, Index): self._Index = Index @property def Delta(self): """增量返回值,流式调用时使用该字段。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.TranslationDelta` """ return self._Delta @Delta.setter def Delta(self, Delta): self._Delta = Delta @property def Message(self): """返回值,非流式调用时使用该字段。 :rtype: :class:`tencentcloud.hunyuan.v20230901.models.TranslationMessage` """ return self._Message @Message.setter def Message(self, Message): self._Message = Message def _deserialize(self, params): self._FinishReason = params.get("FinishReason") self._Index = params.get("Index") if params.get("Delta") is not None: self._Delta = TranslationDelta() self._Delta._deserialize(params.get("Delta")) if params.get("Message") is not None: self._Message = TranslationMessage() self._Message._deserialize(params.get("Message")) memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class TranslationDelta(AbstractModel): """翻译接口返回的内容(流式返回) """ def __init__(self): r""" :param _Role: 角色名称。 :type Role: str :param _Content: 内容详情。 :type Content: str """ self._Role = None self._Content = None @property def Role(self): """角色名称。 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """内容详情。 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content def _deserialize(self, params): self._Role = params.get("Role") self._Content = params.get("Content") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class TranslationMessage(AbstractModel): """翻译接口会话内容 """ def __init__(self): r""" :param _Role: 角色,可选值包括 system、user、assistant、 tool。 :type Role: str :param _Content: 文本内容 :type Content: str """ self._Role = None self._Content = None @property def Role(self): """角色,可选值包括 system、user、assistant、 tool。 :rtype: str """ return self._Role @Role.setter def Role(self, Role): self._Role = Role @property def Content(self): """文本内容 :rtype: str """ return self._Content @Content.setter def Content(self, Content): self._Content = Content def _deserialize(self, params): self._Role = params.get("Role") self._Content = params.get("Content") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set)) class Usage(AbstractModel): """Token 数量 """ def __init__(self): r""" :param _PromptTokens: 输入 Token 数量。 :type PromptTokens: int :param _CompletionTokens: 输出 Token 数量。 :type CompletionTokens: int :param _TotalTokens: 总 Token 数量。 :type TotalTokens: int """ self._PromptTokens = None self._CompletionTokens = None self._TotalTokens = None @property def PromptTokens(self): """输入 Token 数量。 :rtype: int """ return self._PromptTokens @PromptTokens.setter def PromptTokens(self, PromptTokens): self._PromptTokens = PromptTokens @property def CompletionTokens(self): """输出 Token 数量。 :rtype: int """ return self._CompletionTokens @CompletionTokens.setter def CompletionTokens(self, CompletionTokens): self._CompletionTokens = CompletionTokens @property def TotalTokens(self): """总 Token 数量。 :rtype: int """ return self._TotalTokens @TotalTokens.setter def TotalTokens(self, TotalTokens): self._TotalTokens = TotalTokens def _deserialize(self, params): self._PromptTokens = params.get("PromptTokens") self._CompletionTokens = params.get("CompletionTokens") self._TotalTokens = params.get("TotalTokens") memeber_set = set(params.keys()) for name, value in vars(self).items(): property_name = name[1:] if property_name in memeber_set: memeber_set.remove(property_name) if len(memeber_set) > 0: warnings.warn("%s fileds are useless." % ",".join(memeber_set))
Memory