网站首页 > 技术文章 正文
1 简介
大家好我是费老师,markdown作为经典易用的文档格式,随着近几年AI大模型的普及,更是成为了大模型内容输出的标准内容格式。
针对markdown格式的内容,使用Python中的一些宝藏库,我们可以将其轻松转化为可访问的应用页面,并且对markdown中嵌入的latex公式、HTML代码块,以及目前非常流行的内嵌mermaid图表等形式丰富的内容,都可以完美的渲染展示出来,非常适合自建文档、知识库等应用场景。
今天的文章中,我们就来一起学习如何基于Python轻松实现markdown转网页应用~
2 Python轻松实现markdown转网页应用
我们使用Python中的fmc库实现markdown到网页应用的直接转换:
- fmc在线文档地址:https://fmc.feffery.tech
在已激活Python环境的前提下(推荐Python版本在3.8到3.12之间),终端执行下列命令完成对fmc库最新正式版本的安装:
pip install feffery-markdown-components -U
下面我们先通过一个最简单的例子,了解基于fmc渲染markdown的基本方法,fmc依托于Python生态中著名的全栈应用框架Dash,因此下面的示例中,我们通过将fmc的markdown渲染组件放置在应用的页面内容中,便可实现渲染。
app1.py
import dash
import feffery_markdown_components as fmc
app = dash.Dash(__name__)
raw_markdown = """
# 1 示例一级标题
## 1.1 示例二级标题
这是一段*示例内容*。
"""
app.layout = fmc.FefferyMarkdown(markdownStr=raw_markdown)
if __name__ == "__main__":
app.run(debug=True)
终端执行python app1.py,按照输出的地址浏览器访问即可,可以看到对应的markdown内容被正确渲染:
除了常规的markdown内容以外,基于fmc我们还可以渲染内嵌的mermaid图表,以通过deepseek生成的大模型综述内容为例:
对应代码如下,具体设置参考fmc相关在线文档(
https://fmc.feffery.tech/render-mermaid ):
app2.py
import dash
import feffery_markdown_components as fmc
app = dash.Dash(
__name__,
# 使用mermaid图表渲染功能时,需在应用实例化时额外引入必要的mermaid静态资源,譬如下面示例的CDN地址
external_scripts=[
"https://registry.npmmirror.com/mermaid/latest/files/dist/mermaid.min.js"
],
)
raw_markdown = """
以下是简洁的大模型发展综述的Mermaid图表表示:
```mermaid
timeline
title 大模型发展史
section 萌芽期 (2017-2018)
Transformer架构提出 : 2017: Vaswani等提出自注意力机制
GPT-1诞生 : 2018: OpenAI发布1.17亿参数模型
section 快速发展期 (2019-2020)
BERT崛起 : 2019: Google提出双向Transformer
GPT-3突破 : 2020: 1750亿参数模型问世
section 多模态时代 (2021-2022)
CLIP模型 : 2021: 图文跨模态理解
ChatGPT发布 : 2022: 对话能力突破
section 生态竞争期 (2023-)
开源模型爆发 : LLaMA/PaLM等竞品
多模态大模型 : GPT-4V/Gemini
```
```mermaid
graph TD
A[核心技术] --> B[架构创新]
A --> C[规模扩展]
A --> D[训练方法]
B --> B1[Transformer]
B --> B2[Moe结构]
C --> C1[千亿参数]
C --> C2[分布式训练]
D --> D1[RLHF]
D --> D2[提示工程]
```
```mermaid
pie
title 2023年模型参数分布
"百亿级" : 35
"千亿级" : 55
"万亿级" : 10
```
关键发展特征:
1. 模型规模指数增长(2018-2023年参数增长1000倍)
2. 训练范式转变:从监督学习到自监督/强化学习
3. 应用场景扩展:单模态→多模态→智能体系统
4. 技术挑战:推理成本、幻觉问题、安全对齐
注:可根据需要调整时间节点或技术分类,此图表突出关键里程碑和技术维度。
"""
app.layout = fmc.FefferyMarkdown(markdownStr=raw_markdown, mermaidOptions=True)
if __name__ == "__main__":
app.run(debug=True)
在fmc中渲染markdown内嵌的mermaid图表,可以自由指定依赖的mermaid资源版本,使得相关功能非常灵活且稳定,譬如可以完美渲染mermaid中新引入的特殊图表类型,以雷达图为例:
除了上面展示的部分示例以外,通过fmc渲染markdown支持但不限于的功能有(以下示例均来自fmc在线文档:https://fmc.feffery.tech ):
- 内置多种代码块主题
- Latex公式渲染
- 渲染原生HTML
- 自定义代码块样式
- 渲染图片内容
- 各类型元素样式可自定义
- 内置多种主题
- 自动目录生成
- 关键词高亮功能
基于fmc以及Dash应用生态中的其他组件库,我们可以纯Python轻松定制化实现各种文档、知识库类应用。
猜你喜欢
- 2025-07-23 零基础入门AI智能体:智能体介绍(智能体类型)
- 2025-07-23 最新PDF转markdown软件MonkeyOCR整合包,文档图片解析工具
- 2025-07-23 iPadOS 26备忘录再升级:支持通话录音转录、Markdown导出
- 2025-07-23 一款能打破 Markdown 天花板的神器 —— Quarkdown
- 2025-07-23 网上的好文章,一键转存成 Markdown,永久阅读!
- 2025-04-26 3款 .NET 开源的编辑器,包含代码、文本和Markdown编辑功能!
- 2025-04-26 Markdown 格式如何转换成 Word?
- 2025-04-26 jupyter lab修改默认文件目录
- 2025-04-26 一款优秀的微信Markdown编辑神器及私有化部署流程
- 2025-04-26 PDF文件转markdown格式软件Marker1.6.1版整合包下载
- 1517℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 594℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 521℃MySQL service启动脚本浅析(r12笔记第59天)
- 489℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 489℃启用MySQL查询缓存(mysql8.0查询缓存)
- 477℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 456℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 454℃MySQL server PID file could not be found!失败
- 最近发表
-
- PS所有滤镜的说明(六)(ps滤镜详解)
- 5款小白也能用的在线图片编辑器!电商效率飙升就靠它!
- Java变量(java变量有什么作用)
- Java面试常见问题:Java注解(java中的面试题)
- Java编程入门第一课:HelloWorld(java编程从入门到实践)
- Java基础教程:Java继承概述(java里继承的概述)
- java基础之——访问修饰符(private/default/protected/public)
- 如何规划一个合理的JAVA项目工程结构
- 将机器指令翻译成 JavaScript -- 终极目标
- Web 服务器基准测试:Go vs. Node.js vs. Nim vs. Bun
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- c语言min函数头文件 (68)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)