Python轻松实现markdown转网页,完美支持mermaid图表、latex公式
itomcoil 2025-08-03 05:29 3 浏览
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轻松定制化实现各种文档、知识库类应用。
相关推荐
- 前端最常用的25个正则表达式,代码效率提高 80%
-
在日常开发中,正则表达式是非常有用的,正则表达式在每个语言中都是可以使用的,他就跟JSON一样,是通用的。在日常开发中,了解一些常用的正则表达式,能大大提高你的工作效率,例如字符串的匹配表单项的格式校...
- 如何使用正则表达式和 Python 匹配不以模式开头的字符串
-
需要在Python中使用正则表达式来匹配不以给定模式开头的字符串吗?如果是这样,你可以使用下面的语法来查找所有的字符串,除了那些不以https开始的字符串。r"^(?!https).*&...
- Python中使用re模块实现正则表达式的替换字符串操作
-
#编程语言#我是"学海无涯自学不惜!",关注我,一同学习简单易懂的Python编程。0基础学python(83)Python中,导入re模块后还可以进行字符串的替换操作,就是sub()...
- 10分钟快速掌握正则表达式
-
什么是正则表达式,英文名字regularexpression。其实说人话就是:用有限的符号,表达无线的序列。字面量创建正则表达式letstr="jasonlee2023"l...
- C语言中使用正则表达式
-
POSIX规定了正则表达式的C语言库函数,参见regex(3),我们已经学了很多C函数的用法读者应该具备自己看懂man手册的能力C语言中使用正则表达式一般分为三步:1.编译正则表达式regco...
- jmeter(十五)-正则表达式提取器
-
正则表达式提取器(RegularExpressionExtractor)sampler请求的服务器响应结果中通过正则表达式提取值所需值,生成模板字符串,并将结果存储到给定的变量名中。界面如下:Ap...
- 浅学python | 使用正则表达式对象处理字符串
-
分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard学苑。欢迎大家继续访问学苑内容,今天小编为大家带来有关Python的知识。Shareinterest,spread...
- Rocky Linux 9常用命令备忘录(不定时更新)
-
RockyLinux9常用命令备忘录(不定时更新)大家好,我是星哥,上次介绍了<RockyLinux9系统安装配置图解教程并做简单配置>:https://mp.weixin.qq...
- Python教程(十一):循环控制 – break、continue和pass
-
昨天,我们探索了for循环和range()函数。今天,我们将更进一步,学习如何使用三个强大的工具来控制循环内部的流程:break、continue和pass。这些命令让您能够:停止循环(break)...
- pip常用命令,学Python不会这个寸步难行哦(26)
-
小朋友们好,大朋友们好!我是猫妹,一名爱上Python编程的小学生。欢迎和猫妹一起,趣味学Python。今日主题学习下pip的使用。pip什么是pippip全称PythonPackageIndex...
- Python轻松实现markdown转网页,完美支持mermaid图表、latex公式
-
1简介大家好我是费老师,markdown作为经典易用的文档格式,随着近几年AI大模型的普及,更是成为了大模型内容输出的标准内容格式。针对markdown格式的内容,使用Python中的一些宝藏库,我...
- 写 Python 七年才发现的七件事:真正提高生产力的脚本思路
-
如果你已经用Python写了不少脚本,却总觉得代码只是“能跑”,这篇文章或许会刷新你对这门语言的认知。以下七个思路全部来自一线实战,没有花哨的概念,只有可落地的工具与习惯。它们曾帮我省下大量无意义...
- Python sys模块使用教程
-
1.知识导图2.sys模块概述2.1模块定义与作用sys模块是Python标准库中的一个内置模块,提供了与Python解释器及其环境交互的接口。它包含了许多与系统相关的变量和函数,可以用来控制P...
- Python开发效率翻倍!47k星神器uv实测真香
-
在日常Python开发中,你是否经常遇到这些问题:多版本切换复杂-项目间Python版本冲突频发环境管理繁琐-手动创建/激活虚拟环境效率低下依赖安装缓慢-每次pipinstall都像在抽...
- 如何在 Ubuntu Linux 上安装 Python 依赖项
-
对于任何软件项目,管理依赖项是确保顺利运行的必要条件;否则,应用程序可能会出现故障。同样,从事Python应用程序开发的开发人员需要各种库和包,这些被称为依赖项,以完成项目的功能并正确运行它们。...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)