LangChain入门:11.Pydantic(JSON)解析器实战

2024-04-03 14:52

本文主要是介绍LangChain入门:11.Pydantic(JSON)解析器实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

摘要

在数字化营销的浪潮中,自动化内容生成成为了提升效率和用户参与度的利器。本文将详细介绍如何利用LangChain的自然语言处理能力和Pydantic的数据验证特性,构建一个自动化的花店文案生成器。通过这个工具,您可以快速为各种花卉生成吸引人的描述和推荐理由,从而提升营销效果和客户体验。

环境准备

在开始之前,请确保您的Python环境中已安装以下库:langchain_openaipandaspydantic。如果尚未安装,可以通过以下命令一次性完成安装:

pip install langchain_openai pandas pydantic
Pydantic库简介

Pydantic是一个开源的Python库,用于数据验证和设置管理。它通过使用Python类型提示来验证输入数据,确保数据符合预期的格式和结构。Pydantic特别适合于处理来自API、数据库或其他数据源的输入,因为它可以自动生成数据模型,并在数据不符合预期时提供清晰的错误信息。

创建模型实例

首先,我们需要创建一个OpenAI模型实例,这里选用gpt-3.5-turbo模型,它以生成高质量文本而闻名。

from langchain_openai import ChatOpenAI# 从环境变量中读取OpenAI API密钥
api_key = os.getenv("OPENAI_API_KEY")
llm = ChatOpenAI(openai_api_key=api_key,base_url="https://api.chatanywhere.tech/v1",model="gpt-3.5-turbo",temperature=0,
)
定义数据结构

使用Pydantic库定义我们期望的数据格式,确保模型输出的一致性和可验证性。

from pydantic import BaseModelclass FlowerDescription(BaseModel):flower_type: strprice: intdescription: strreason: str
创建输出解析器

创建一个输出解析器,确保模型的输出符合我们定义的FlowerDescription格式。

from langchain.output_parsers import PydanticOutputParseroutput_parser = PydanticOutputParser(pydantic_object=FlowerDescription)
format_instructions = output_parser.get_format_instructions()
构建提示模板

定义一个提示模板,指导模型生成符合我们期望格式的输出。

from langchain import PromptTemplateprompt_template = """
您是一位专业的花店文案撰写人。
对于售价为{price}的{flower},您能提供一个吸引人的描述和一个推荐的理由吗?
{format_instructions}
"""
生成并解析输出

使用定义好的模板和解析器生成文案,并解析模型的输出。

import pandas as pd# 创建DataFrame来存储结果
df = pd.DataFrame(columns=["flower_type", "price", "description", "reason"])# 数据准备
flowers = ["玫瑰", "康乃馨", "郁金香", "百合", "向日葵"]
prices = [10, 15, 20, 25, 30]# 循环处理每种花卉
for flower, price in zip(flowers, prices):input_prompt = prompt_template.format(flower=flower, price=price)output = llm.invoke(input_prompt)# 解析模型输出parsed_output = output_parser.parse(output.content)parsed_output_dict = parsed_output.dict()# 将结果添加到DataFramedf = df.append(parsed_output_dict, ignore_index=True)# 打印结果
print(df.to_dict(orient="records"))
效果展示

以下是一个成功生成的花卉文案示例:
在这里插入图片描述
图2: 自动生成的花卉文案展示。

效果与结论

通过上述步骤,我们成功构建了一个自动化的花店文案生成器。这个工具不仅可以节省宝贵的时间,还能确保内容的质量和一致性。利用LangChain和Pydantic库,我们不仅确保了输出数据的准确性,还提高了数据处理的效率。

这个项目展示了LangChain在处理和生成复杂数据结构方面的强大能力,以及Pydantic在数据验证和设置管理中的实用性。

这篇关于LangChain入门:11.Pydantic(JSON)解析器实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/873222

相关文章

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读