当前位置: 首页 > news >正文

做营销型网站哪家好如何帮网站

做营销型网站哪家好,如何帮网站,京东网站建设的主旨,云南网站建设崇左文章目录 一 LangChain 自定义工具概述二创建自定义工具的三种方法2.1 方法一#xff1a;tool 装饰器2.1.1 同步方法案例2.1.2 工具描述方式1#xff1a;传参2.1.3 工具描述方式2#xff1a;文档字符串 2.2 方法二#xff1a;StructuredTool类2.2.1 StructuredTool创建自定… 文章目录 一 LangChain 自定义工具概述二创建自定义工具的三种方法2.1 方法一tool 装饰器2.1.1 同步方法案例2.1.2 工具描述方式1传参2.1.3 工具描述方式2文档字符串 2.2 方法二StructuredTool类2.2.1 StructuredTool创建自定义工具2.2.2 StructuredTool配置信息 2.3 方法三BaseTool类 三 异步工具的实现四 工具错误处理策略 一 LangChain 自定义工具概述 LangChain提供了一套工具、组件和接口可简化创建由大型语言模型(LLM)和聊天模型提供支持的应用程序的过程。在构建智能代理时为其提供合适的工具是确保其强大功能的关键LangChain作为一个支持创建和管理工具的框架能让开发者以模块化方式扩展代理的能力。 当构建代理时需要为其提供一组工具列表代理可以使用这些工具。除了调用的实际函数之外工具由几个组件组成 name(str)是必需的并且在提供给代理的工具集中必须是唯一的description(str)是可选的但建议的因为代理使用它来确定工具的使用方式return_direct(bool)默认为Falseargs_schema(PydanticBaseModel)是可选的但建议的可以用于提供更多信息或用于验证预期参数。 二创建自定义工具的三种方法 LangChain为开发人员提供了不同的方式来创建工具这些工具可以被智能代理或语言模型调用。 第一种方法是使用tool装饰器(定义自定义工具的最简单方法)第二种方法是使用StructuredTool类允许更细粒度的配置而无需过多的代码第三种方法是基于BaseTool类构造子类显式自定义工具工具定义提供最大限度的把控但需要做更多的工作。 2.1 方法一tool 装饰器 使用tool修饰符是自定义工具最简单的方法。默认情况下修饰符用函数的名字作为工具名称但传字符串作为第一个参数可以重命名工具名称。例如可以创建一个总是返回字符串LangChain的虚构搜索函数或者将两个数字相乘的乘法函数。这些函数最大的区别是第一个函数只有一个输入第二个函数需要多个输入。 2.1.1 同步方法案例 from langchain_core.tools import tool tool def multiply(a:int,b:int)-int:Multiply two numbersreturn a*bprint(multiply.name) # multiply print(multiply.description) # Multiply two numbers print(multiply.args) # {a: {title: A, type: integer}, b: {title: B, type: integer}}2.1.2 工具描述方式1传参 通过将工具名称和 JSON 参数传递给工具装饰器进行自定义 from langchain_core.tools import tool from pydantic import BaseModel, Fieldclass CalculatorInput(BaseModel):a: int Field(descriptionThe first number)b: int Field(descriptionThe second number)tool(multiplication-tool, args_schemaCalculatorInput, return_directTrue) def multiply(a: int, b: int) - int:Multiply two numbersreturn a * bprint(multiply.name) # multiplication-tool print(multiply.description) # Multiply two numbers print(multiply.args) # {a: {title: A, type: integer}, b: {title: B, type: integer}} print(multiply.return_direct) # True2.1.3 工具描述方式2文档字符串 tool 可以选择性地解析 Google 风格文档字符串并将文档字符串组件如参数描述与工具模式的相关部分关联起来。 tool(parse_docstringTrue) def foo(bar: str, baz: int) - str:The foo.Args:bar: The bar.baz: The baz.return bar foo.args_schema.schema(){description: The foo.,properties: {bar: {description: The bar.,title: Bar,type: string},baz: {description: The baz., title: Baz, type: integer}},required: [bar, baz],title: fooSchema,type: object}2.2 方法二StructuredTool类 使用StructuredTool类允许更细粒度的配置而无需过多的代码 2.2.1 StructuredTool创建自定义工具 使用StructuredTool的from_function可以创建自定义工具包含两个参数func,coroutine分别指定同步方法和异步方法。 import asyncio from langchain_core.tools import StructuredTooldef multiply(a:int,b:int)-int:Multiply two numbersreturn a*b async def a_multiply(a:int,b:int)-int:Multiply two numbersreturn a*basync def main():calculatorStructuredTool.from_function(funcmultiply,coroutinea_multiply)print(calculator.run({a:2, b:3}))print(calculator.invoke({a:2, b:3}))print(await calculator.ainvoke({a:2, b:5}))asyncio.run(main())2.2.2 StructuredTool配置信息 import asyncio from langchain_core.tools import StructuredTool from pydantic import Field, BaseModelclass CalculatorInput(BaseModel):a: int Field(descriptionThe first number)b: int Field(descriptionThe second number)#创建同步、异步包装器函数 def multiply(a:int,b:int)-int:Multiply two numbersreturn a*b async def async_multiply(a:int,b:int)-int:Multiply two numbersreturn a*basync def main():calculatorStructuredTool.from_function(funcmultiply,namecalculator,descriptionMultiply two numbers,args_schemaCalculatorInput,coroutineasync_multiply,return_directTrue)print(calculator.name)print(calculator.description)print(calculator.args)asyncio.run(main())2.3 方法三BaseTool类 接受字符串或 dict 输入的 LangChain Runnables 可以使用 as_tool 方法转换为工具该方法允许为参数指定名称、描述和其他模式信息。 # 导入所需的模块 from langchain_core.language_models import GenericFakeChatModel # 导入一个假的聊天模型用于测试 from langchain_core.output_parsers import StrOutputParser # 导入字符串输出解析器 from langchain_core.prompts import ChatPromptTemplate # 导入聊天提示模板# 创建一个聊天提示模板包含一个占位符 {answer_style} prompt ChatPromptTemplate.from_messages([(human, Hello. Please respond in the style of {answer_style}.)] )# 创建一个假的聊天模型实例并提供一个固定的响应 llm GenericFakeChatModel(messagesiter([hello matey]))# 构建一个链式调用先应用提示模板然后调用 LLM最后解析输出为字符串 chain prompt | llm | StrOutputParser()# 将 chain 转换为一个工具Tool并指定名称和描述 as_tool chain.as_tool(nameStyle responder, descriptionDescription of when to use tool. )# 打印工具的参数信息 print(as_tool.args) # {answer_style: {title: Answer Style, type: string}}三 异步工具的实现 LangChain的工具可以实现异步版本以节省计算资源和提高效率。在定义异步工具时需要使用async/await语法并确保函数和工具名准确反映功能提供详细的文档字符串。对于涉及外部API调用的工具建议使用API代理服务来提高访问的稳定性并确保异步工具充分利用并发优势避免阻塞操作。 from langchain_core.tools import tooltool async def multiply(a:int,b:int)-int:Multiply two numbersreturn a*bprint(multiply.name) # multiply print(multiply.description) # Multiply two numbers print(multiply.args) # {a: {title: A, type: integer}, b: {title: B, type: integer}}四 工具错误处理策略 为了让代理能从错误中恢复并继续执行需要特定的错误处理策略。可以抛出ToolException并定义错误处理函数设置handle_tool_error属性来定义工具错误的应对策略可以是字符串、布尔值或函数。需要注意的是仅引发ToolException是无效的需要先设置该工具的handle_tool_error因为它的默认值为False。 from langchain_core.tools import StructuredTool from langchain_core.tools import ToolExceptiondef get_weather(city: str) - str:获取给定城市的天气。raise ToolException(f错误没有名为{city}的城市。)get_weather_tool StructuredTool.from_function(funcget_weather,# 默认情况下如果函数抛出TooLException则将TooLException的message作为响应。# 如果设置为True则将返回TooLException异常文本False将会抛出TooLExceptionhandle_tool_errorTrue, )response get_weather_tool.invoke({city:天京}) print(response) # 错误没有名为天京的城市。定义异常处理 from langchain_core.tools import StructuredTool from langchain_core.tools import ToolExceptiondef get_weather(city: str) - str:获取给定城市的天气。raise ToolException(f错误没有名为{city}的城市。)get_weather_tool StructuredTool.from_function(funcget_weather,handle_tool_error没有找到这个城市, )response get_weather_tool.invoke({city:天京}) print(response) # 没有找到这个城市异常个性化处理 from langchain_core.tools import StructuredTool from langchain_core.tools import ToolExceptiondef get_weather(city: str) - str:获取给定城市的天气。raise ToolException(f错误没有名为{city}的城市。)def _handle_tool_error(error: ToolException) - str:处理工具错误。return f工具执行期间发生以下错误{error.args[0]}get_weather_tool StructuredTool.from_function(funcget_weather,handle_tool_error_handle_tool_error )response get_weather_tool.invoke({city:天京}) print(response) # 工具执行期间发生以下错误错误没有名为天京的城市。
http://www.pierceye.com/news/77036/

相关文章:

  • 黄岛建网站网页设计与网站建设作品
  • 做的最好的相亲网站有哪些wordpress 判断登录
  • 不知此网站做男人也做的比较好的旅行网站
  • 建立网站需要多少钱一个酷家乐装修设计软件app下载
  • 陕西网站备案查询拖拽建站平台
  • 做网站配送地址怎么变换沧州网页设计百胜
  • 佛山网站建设明细深圳建工集团股份有限公司待遇
  • 手机网站开发技术pdf网站建设注册小程序
  • 济南优化网站的哪家好上海住房和城市建设厅网站
  • 物业公司网站模板这几年做啥网站能致富
  • 贾汪建设局网站用sqlite3做网站
  • 大连企业网站建设模板十大黄金软件app
  • show t团队网站艰涩wordpress study
  • 汕头网站建设方案书win7建设网站
  • 北京建设局网站百度推广代理赚钱
  • 毕业设计题网站开发旅游网站设计与制作课程设计
  • 大型集团网站建设江阴外贸网站建设公司
  • 怎样通过网址浏览自己做的网站wordpress所有栏目循环输出
  • 网站开发需不需要考研网站域名怎样注销
  • 做美食的网站有哪些上海城乡建设网站证件查询
  • 美橙西安网站备案拍照美工自学网
  • 广东专业网站开发dw软件使用教程
  • 手机参数对比的网站河北人工智能建站系统软件
  • 贸易公司网站建设一个网站如何优化
  • 做网站需要下载啥wordpress 代码规范
  • 做教育机构网站上海app开发网站建设
  • 网站开发处理大量用户请求wordpress 简约博客
  • 黑龙江网站建设企业网络公司做机场网站
  • 网站开发中 整体框架的架构社区做图网站
  • 好用的做图网站wordpress+路由器