利用AI大模型和Mermaid生成流程图

ops/2025/1/12 13:08:47/

核心点1:利用大模型生成流程图的语句(Code)

  1. 确定业务流程

    • 用户需要明确要绘制的业务流程,包括主要步骤、决策点以及各步骤之间的关系。
    • 将确定的业务流程以文字形式描述出来。
  2. 生成Mermaid代码

    • 将描述好的业务流程交给大模型(如ChatGPT),让其生成相应的Mermaid代码。
    • 大模型会根据输入的业务流程描述,自动生成符合Mermaid语法的代码。

例如,假设我们要绘制一个用户登录的业务流程图,内容包括用户登录、检查用户权限、显示内容或权限错误以及用户注销等步骤。描述业务流程如下:

  • 用户登录
  • 检查用户权限
  • 如果权限有效,显示内容;否则显示权限错误
  • 用户可以选择注销

将上述业务流程描述交给ChatGPT,生成如下Mermaid代码:

PlainText

graph TB
A[用户登录]-->B[检查用户权限]
B--权限有效-->C[显示内容]
B--权限无效-->D[显示权限错误]
C-->E[用户操作]

核心点2:利用Mermaid的开源API将Code转换成流程图片

  1. 渲染流程图

    • 将生成的Mermaid代码放入支持Mermaid的环境中,如在线免费网站(Online FlowChart & Diagrams Editor - Mermaid Live Editor),进行渲染生成流程图。
    • 用户可以根据自己的需求对生成的流程图进行调整和优化。
  2. 下载或引用图片

    • 将生成的流程图按照自己需要的格式下载下来,或者直接引用当前图片的链接,将其嵌入到文档中。

Mermaid API的详细使用

Mermaid提供了丰富的API方法,使得在网页中创建和展示各种类型的图表变得非常方便。以下是一些关键步骤:

  • 初始化图表: 使用mermaid.initialize方法可以初始化一个流程图,该方法接受一个可选的配置对象作为参数,用于自定义图表的样式和行为。

  • 添加节点和消息: 使用mermaidAPI.add方法可以向流程图中添加节点或消息。节点定义字符串可以使用-->表示节点之间的连接关系。

  • 渲染图表: 使用mermaidAPI.render方法可以将流程图渲染到指定的元素中。渲染后,图表将自动根据元素的大小进行布局和缩放,以适应不同的屏幕尺寸。

示例代码与流程

以下是一个完整的示例流程,展示了如何使用大模型和Mermaid API生成业务流程图:

  1. 确定业务流程并描述: 例如,用户登录、检查权限、显示内容或权限错误、用户注销等步骤。

  2. 使用大模型生成Mermaid代码: 将业务流程描述交给ChatGPT或其他大模型,生成Mermaid代码。

  3. 在Mermaid环境中渲染: 将生成的Mermaid代码粘贴到支持Mermaid的在线网站(如Online FlowChart & Diagrams Editor - Mermaid Live Editor)中进行渲染。

  4. 下载或引用图片: 根据需要下载生成的流程图图片,或直接引用其链接嵌入到文档中。

注意事项

  • 确保大模型能够准确理解并生成符合Mermaid语法的代码。
  • 根据实际需求调整和优化生成的流程图。
  • 注意Mermaid API的版本兼容性,确保使用的API方法在当前版本中有效。

通过以上步骤,你可以高效地利用大模型和Mermaid实现业务流程图的快速生成,并将其应用于各种文档和项目中。

代码:

# Mermaid Live Editor APIapi_url = "https://mermaid.ink/img/"full_url = f"{api_url}{base64_str}"# 下载图片response = requests.get(full_url)if response.status_code == 200:# 确保目录存在os.makedirs(upload_dir, exist_ok=True)# 保存图片with open(output_path, 'wb') as f:f.write(response.content)print(f"图片已保存到: {output_path}")print(f"访问链接: {full_url}")return output_pathelse:print(f"错误: {response.status_code}")print(f"URL: {full_url}")return None


http://www.ppmy.cn/ops/149452.html

相关文章

Windows下调试Dify相关组件(2)--后端Api

1.部署依赖的服务(代码最外层的docker目录) 1.1 将middleware.env.example复制,并改名为middleware.env。 1.2 查看docker-compose.middleware.yaml,有5个服务 db:postgres数据库。 redis:redis缓存。 sa…

[ComfyUI]接入Google的Whisk,巨物融合玩法介绍

一、介紹​ 前段时间,谷歌推出了一个图像生成工具whisk,有一个很好玩的图片融合玩法,分别提供三张图片,就可以任何组合来生成图片。​ ​ 最近我发现有人开发了对应的ComfyUI插件,对whisk做了支持,就来体验了下&#…

2024年12月中国电子学会青少年软件编程(Python)等级考试试卷(二级)答案 + 解析

2024.12 中国电子学会青少年软件编程(Python)等级考试试卷(二级)答案 解析 一、单选题(共25题,共50分) 1. 已知字典如下 dic1 { name: Ming, age:20, grade: A, Tel:6666666 } 以下哪个代码运行结果为20&#xff…

多个表单使用相同的 ref 和 rules,表单验证规则不生效

在 Vue 和 Element UI 中,如果多个表单使用相同的 ref 和 rules,可能会导致表单验证规则不生效。这是因为 ref 是唯一的,多个表单共享同一个 ref 会导致冲突。 解决方法: 1. 为每个表单设置不同的 ref 为每个表单设置不同的 re…

VTK知识学习(29)-交互问题

1、窗体类型 1)、RenderWindowControl UserControl derived implementation of vtkRenderWindow for use in Windows Forms applications. The client area of this UserControl is completely filled with an instance of a vtkRenderWindow. 用于Windows窗体应…

本地系统A与云平台B数据对接demo演示

.一、云平台B提供工程类库【.net工程类库,直接调用】 本地系统A-本地电脑调用,电脑连接互联网 云平台B-互联网云平台-提供cs文件,接口文档。 1.c#类库 2.控制台或winform直接调用c#类库; 3.云平台B输出【c#源文件】 4.cs文件端…

【数据链电台】洛克希德·马丁(Lockheed Martin)

洛克希德马丁公司(Lockheed Martin)是全球领先的航空航天、国防、先进技术和安全领域的供应商之一。 公司为美军及盟国军队提供了广泛的通信系统,包括数据链电台和相关的通信系统。 洛克希德马丁的许多产品用于战术通信、卫星通信、电子战、…

Hadoop 实战笔记(一) -- Windows 安装 Hadoop 3.x

环境准备 安装 JAVA 1.8 Java环境搭建之JDK下载及安装下载 Hadoop 3.3.5 安装包 Hadoop 下载:https://archive.apache.org/dist/hadoop/common/ 一、JAVA JDK 环境检查 二、Hadoop(HDFS)环境搭建 1. 解压安装文件 hadoop-3.3.5.tar 2. 配置环境变量 HADOOP_HO…