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

核心点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. 渲染流程图

  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 API
    api_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_path
    else:
        print(f"错误: {response.status_code}")
        print(f"URL: {full_url}")
        return None
相关推荐
想不明白的过度思考者几秒前
Spring IoC 与 DI 深度剖析:从“控制反转”到 Bean 的集中管理
java·spring·ioc·di
南河的南几秒前
解决IDEA无法下载Maven仓库的源码
java·maven·intellij-idea
无名-CODING4 分钟前
#Servlet与Tomcat完全指南 - 从入门到精通(含面试题)
java·servlet·tomcat
想个名字太难7 分钟前
ElasticSearch编程操作
java·elasticsearch·全文检索
Keep_Trying_Go8 分钟前
基于Transformer的目标统计方法(CounTR: Transformer-based Generalised Visual Counting)
人工智能·pytorch·python·深度学习·transformer·多模态·目标统计
小马爱打代码10 分钟前
Spring AI:RAG 增强检索介绍
java·人工智能·spring
Franciz小测测11 分钟前
Python APScheduler 定时任务 独立调度系统设计与实现
java·数据库·sql
追风少年ii16 分钟前
脚本测试--R版本 vs python版本的harmony整合效果比较
linux·python·机器学习·空间·单细胞·培训
天一生水water22 分钟前
Eclipse数值模拟软件详细介绍(油藏开发的“工业级仿真引擎”)
java·数学建模·eclipse
谷粒.2 小时前
Cypress vs Playwright vs Selenium:现代Web自动化测试框架深度评测
java·前端·网络·人工智能·python·selenium·测试工具