AI Agent系列(八) -基于ReAct架构的前端开发助手(DeepSeek)

news2025/5/15 23:41:33

AI Agent系列【八】

  • 项目目标
  • 一、核心功能设计
  • 二、技术栈选择
  • 三、Python实现
    • 3.1 设置基础环境
    • 3.2 定义AI前端生成的类
    • 3.4 实例化
    • 3.5 Flask路由
    • 3.6 主程序执行
  • 四、 功能测试


项目目标

开发一个能够协助HTML+JS+CSS前端设计的AI Agent,通过在网页中输入相应的问题,此应用能自动生成对应的html文件设计的前端程序,并通过flask架构下实现自动跳转到对应界面来完成功能验证。

一、核心功能设计

AI Agent应该具备以下能力:

  • 根据自然语言描述生成前端代码

  • 分析现有代码并提供优化建议

  • 回答前端相关问题

  • 自动修复常见错误

二、技术栈选择

  • 语言模型: DeepSeek
  • 开发框架: Flask
  • 前端交互: html +CSS +JS

三、Python实现

3.1 设置基础环境

需要安装的工具包包含LLM的API工具包openai,网页应用开发框架flask,dot的python环境python-dotenv,Json文件解析json。

# 安装必要库
pip install openai flask python-dotenv requests json

3.2 定义AI前端生成的类

在这个类库中,需要考虑如下功能的实现:

  1. 初始化,需要实现基于LLM的API的客户端初始化,基于ReAct架构的提示词;
  2. 获取响应,基于LLM和系统提示词,用户输入的需求获取的响应信息;
  3. 响应解析,解析基于ReAct架构的响应;
  4. 生成html文件,基于响应的解析结果,生成html文件;
import os
from dotenv import load_dotenv
from datetime import datetime
from flask import Flask, request, render_template
from openai import OpenAI
import json

load_dotenv()


class DeepSeekAICodeAssistant:
    def __init__(self):
        self.api_key = os.getenv("DEEPSEEK_API_KEY")
        self.base_url = "https://api.deepseek.com"
        self.model = "deepseek-chat"
        self.client = OpenAI(api_key=self.api_key, base_url=self.base_url)
        self.context = []
        self.system_prompt = """
        你是一个专业的前端开发助手,采用ReAct(Reasoning+Acting)架构工作。
        请按照以下JSON格式响应:
        {
            "thought": "分析...",
            "action": "执行...",
            "code": "生成的代码...",
            "advice": "优化建议..."
        }
        """
        self._init_context()

    def _init_context(self):
        """初始化对话上下文"""
        self.context = [
            {"role": "system", "content": self.system_prompt}
        ]

    def generate_response(self, user_input):
        """
        调用DeepSeek API生成响应
        :param user_input: 用户输入
        :return: 解析后的响应内容或错误信息
        """
        try:
            self.context.append({"role": "user", "content": user_input})

            response = self.client.chat.completions.create(
                model=self.model,
                messages=self.context,
                stream=False
            )

            assistant_reply = response.choices[0].message.content
            self.context.append({"role": "assistant", "content": assistant_reply})

            return self._parse_react_response(assistant_reply)

        except (KeyError, json.JSONDecodeError) as e:
            return {"error": f"响应解析失败: {str(e)}"}
        except Exception as e:
            return {"error": f"未知错误: {str(e)}"}

    def _parse_react_response(self, response_text):
        """解析ReAct格式的响应"""
        try:
            data = json.loads(response_text)
            return {
                "thought": data.get("thought", "无"),
                "action": data.get("action", "无"),
                "code": data.get("code", "无代码生成"),
                "advice": data.get("advice", "无优化建议")
            }
        except json.JSONDecodeError:
            return {
                "thought": "直接响应",
                "action": "生成代码",
                "code": response_text,
                "advice": ""
            }

    def generate_html_output(self, react_response, output_file="templates/output.html"):
        """生成HTML输出文件,仅保存生成的代码"""
        timestamp = datetime.now().strftime("%Y-%m-%d %H:%M:%S")

        # 只提取代码部分
        generated_code = react_response.get('code', '无代码生成')

        html_template = f"""<!DOCTYPE html>
            <html>
            <head>
                <title>AI前端助手 - {timestamp}</title>
                <style>
                    body {{ font-family: Arial, sans-serif; margin: 20px; }}
                    pre {{ background: #eee; padding: 10px; overflow-x: auto; }}
                </style>
            </head>
            <body>
                <h1>生成的响应式导航栏</h1>
                <pre>{generated_code}</pre>
            </body>
            </html>"""

        os.makedirs(os.path.dirname(output_file), exist_ok=True)
        with open(output_file, "w", encoding="utf-8") as f:
            f.write(html_template)
        return output_file
        

3.4 实例化

需要实例化flask和预定义的 DeepSeekAICodeAssistant

# Flask应用
app = Flask(__name__)
assistant = DeepSeekAICodeAssistant()

3.5 Flask路由

在路由中定义POST方法,当前端中输入了对应的需求后,将调用之前定义的获取响应和生成对应的html文件的功能。
当文件生成后,系统自动重定向到对应的文件进行代码的验证。


@app.route("/", methods=["GET", "POST"])
def index():
    if request.method == "POST":
        prompt = request.form.get("prompt")
        if prompt:
            result = assistant.generate_response(prompt)
            if "error" not in result:
                assistant.generate_html_output(result)
                return render_template("output.html")
            return f"<p style='color:red'>错误: {result['error']}</p>"

    return """
    <form method="POST">
        <h2>DeepSeek前端助手</h2>
        <textarea name="prompt" rows="5" cols="60" placeholder="输入你的前端需求..."></textarea><br>
        <button type="submit">生成代码</button>
    </form>
    """

3.6 主程序执行

至此,我们只需要通过main函数执行flask即可。

if __name__ == "__main__":
    app.run(debug=True)

四、 功能测试

代码执行后,在浏览器输入如下地址:http://127.0.0.1:5000,输入需求-生成一个科学计算器。
在这里插入图片描述点击代码生成后,系统将调转到生成的网页,进行功能测试。
在这里插入图片描述
AI Agent系列(八) -基于ReAct架构的前端开发助手(DeepSeek)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328386.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一文学会云服务器配置Milvus向量数据库

服务器准备 首先&#xff0c;我们需要进行服务器的准备&#xff0c;这里准备的是RTX-4090服务器 连接我们已经创建好的服务器&#xff0c;这里可使用MobaXterm进行ssh连接 ssh funhpcIP地址 一键完成Docker配置 注&#xff1a;docker的旧版本不一定被称为docker&#xff0c;doc…

19685 握手问题

19685 握手问题 ⭐️难度&#xff1a;简单 &#x1f31f;考点&#xff1a;2024、省赛、数学 &#x1f4d6; &#x1f4da; package test ;import java.util.Scanner; public class Main {public static void main(String[] args) {Scanner scanner new Scanner(System.in);…

【MySQL数据库】锁机制

概述 锁&#xff1a;是计算机协调多个进程或者线程并发访问某一资源的机制。在数据库中&#xff0c;除了传统的计算资源&#xff08;CPU、RAM、IO&#xff09;的争用以外。数据也是一种供多用户共享的资源。如何保证数据的并发访问的一致性、有效性是所有数据库必须解决的一个…

react redux的学习,单个reducer

redux系列文章目录 一 什么redux&#xff1f; redux是一个专门用于做状态管理的JS库(不是react插件库)。它可以用在react, angular, vue等项目中, 但基本与react配合使用。集中式管理react应用中多个组件共享的状 简单来说&#xff0c;就是存储页面的状态值的一个库&#xf…

分布式控制技术赋能智慧工厂精准控制研究

摘要&#xff1a;本文聚焦于分布式控制技术在智慧工厂精准控制中的应用。详细阐述了分布式控制系统&#xff08;DCS&#xff09;、边缘计算机、边边协同技术以及分布式计算等关键要素在实现精准控制中的作用机制。同时&#xff0c;分析了云边协同模式存在占用带宽、单点故障、数…

清明节里清明菜:软萩(拟人版介绍)

好像人们无论过任何节&#xff0c;总是离不开吃 清明节里吃清明菜&#xff0c;你采摘了吗&#xff1f; 姓名 软萩&#xff0c;也叫鼠麴草、清明菜、软雀&#xff0c;学名鼠曲草。 一些地方性小名&#xff08;防止大家找不到组织&#xff0c;已知的都附上&#xff09;&#xf…

JavaWeb学习--MyBatis-Plus整合SpringBoot的ServiceImpl方法(增加,修改与删除部分)

接下来是常用的增加&#xff0c;修改以及删除部分 首先是增加部分&#xff0c;增加一个新的数据 Testpublic void testInsert() {// 添加一个新用户记录Student s new Student();s.setName("NewStudent");s.setAge(25);boolean saved studentService.save(s);//可以…

AiCube 试用 - 创建流水灯工程

AiCube 试用 - 创建流水灯工程 本文介绍了 Aiapp-ISP 仿真调试平台软件的 AiCube 工具&#xff0c;实现流水灯工程的快速创建的主要流程。 下载运行 下载 最新版 AIapp-ISP 软件&#xff1b; 解压并打开该软件&#xff0c;右侧操作界面选择并进入 Keil 仿真设置 标签项&…

GISBox:核心功能免费的一站式三维GIS处理平台

大家好&#xff0c;今天为大家介绍的软件是GISBox&#xff1a;一款核心功能免费的一站式三维GIS处理平台&#xff0c;主要是适用于数字孪生。下面&#xff0c;我们将从软件的主要功能、支持的系统、软件官网等方面对其进行简单的介绍。 软件官网&#xff1a;http://www.gisbox.…

【论文笔记】DeepSeek-R1 技术报告

最强开源LLM&#xff0c;性能和效果都很棒&#xff1b;在数学、代码这种有标准正确答案的场景&#xff0c;表现尤为突出&#xff1b;一些其他场景的效果&#xff0c;可能不如DeepSeek-V3和Qwen。 Deepseek-R1没有使用传统的有监督微调sft方法来优化模型&#xff0c;而使用了大规…

基于javaweb的SSM羽毛球会员俱乐部系统场馆课程运动设计与实现(源码+文档+部署讲解)

技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;免费功能设计、开题报告、任务书、中期检查PPT、系统功能实现、代码编写、论文编写和辅导、论文…

[dp4_路径问题] 下降路径最小和 | 最小路径和 | 地下城游戏

目录 1.下降路径最小和 题解 2.最小路径和 题解 3.地下城游戏 题解 做算法题的时候&#xff0c;谨记图画得越详细越好&#xff0c;思路想的越清晰越好&#xff0c;然后再用代码实现一下就好啦 1.下降路径最小和 链接&#xff1a;931. 下降路径最小和 给你一个 n x n 的…

EasyExcel 数据字典转换器实战:注解驱动设计

一、场景痛点与解决方案 1. 问题背景 在 Excel 导入导出场景中&#xff0c;开发者常面临以下问题&#xff1a; 数据可读性差&#xff1a;数据库存储的字典值&#xff08;如 1、true&#xff09;直接导出时难以理解双向转换复杂&#xff1a;导入时需将用户输入的标签反向解析…

解决STM32CubeMX中文注释乱码

本人采用【修改系统环境变量】的方法 1. 使用快捷键 win X&#xff0c;打开【系统R】&#xff0c;点击【高级系统设置】 2. 点击【环境变量】 3. 点击【新建】 4.按图中输入【JAVA_TOOL_OPTIONS】和【-Dfile.encodingUTF-8】&#xff0c;新建环境变量后重启CubeMX即可。 解释…

AI产品的上层建筑:提示词工程、RAG与Agent

上节课我们拆解了 AI 产品的基础设施建设&#xff0c;这节课我们聊聊上层建筑。这部分是产品经理日常工作的重头戏&#xff0c;包含提示词、RAG 和 Agent 构建。 用 AI 客服产品举例&#xff0c;这三者的作用是这样的&#xff1a; 提示词能让客服很有礼貌。比如它会说&#x…

基于自定义注解+反射+AOP+Redis的通用开关设计:在投行交易与风控系统的落地实践

一句话总结&#x1f923; 一个注解让业务逻辑自动切换&#xff0c;Redis当起了隐形操盘手 业务痛点和需求场景 交易系统需支持毫秒级动态切换报价策略&#xff0c;如切换到备用流动性通道风控模型需支持灰度发布&#xff08;10%流量测试新权重算法&#xff09;和紧急熔断&am…

RK3588使用笔记:ubuntu/麒麟系统功能测试程序

一、前言 本编文章记录在使用嵌入式系统中的一些功能测试demo程序&#xff0c;大部分都是AI写的&#xff0c;哈哈哈&#xff0c;确实很有帮助&#xff0c;但是得根据自身设备实际情况和知道如何问AI&#xff0c;才能得出你想要的结果&#xff0c;本文就记录一些ubuntu/麒麟系统…

深度学习deeplearn3

# Jupyter Notebook魔法命令&#xff0c;用于在Notebook中内联显示图表 %matplotlib inline# 导入NumPy库&#xff0c;用于高效的数值计算 import numpy as np# 从matplotlib_inline库导入backend_inline模块&#xff0c;用于设置图表显示格式 from matplotlib_inline import b…

Mac强制解锁APP或文件夹

当Mac安装过火绒企业版、云安全访问服务之类的APP需要卸载的时候&#xff0c;会发现需要管理员密码&#xff0c;正常的卸载流程走不下去&#xff0c;直接删除APP&#xff0c;会提示“不能完成此操作&#xff0c;xxx已锁定”的信息&#xff0c;此处就记录一下如何关闭锁定状态&a…

SQL语句(二)—— DML

目录 一、添加数据 1、给指定字段添加数据 2、给全部字段添加数据 3、批量添加数据 二、修改数据 1、修改数据的具体语法 2、案例分析 3、注意事项 三、删除数据 1、删除数据的具体语法 2、案例 3、注意事项 DML全称是Data Manipulation Language&#xff0c;即数据…