本文主要是介绍Java实现将Markdown转换为纯文本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案...
以下是两种在 Java 中实现 Markdown 转纯文本的主流方法,根据需求选择适合的方案:
方法一:使用正则表达式(轻量级方案)
适用于简单 Markdown 内容的快速转换
import java.util.regex.Pattern;
public class MarkdownToText {
// 定义 Markdown 常见语法正则表达式
private static final Pattern[] MARKDOWN_PATTERNS = {
Pattern.compile("\\[(.*?)\\]\\(.*?\\)"), // 链接 [text](url)
Pattern.compile("!\\[.*?\\]\\(.*?\\)"), // 图片 
Pattern.compile("`{3,}[\\s\\S]*?`{3,}"), // 代码块 ```code```
Pattern.compile("`(.+?)`"), // 行内代码 `code`
Pattern.compile("^[#]{1,6}\\s*"), // 标题 # ## ###
Pattern.compile("\js\*{1,2}(.*?)\\*{1,2}"), // 加粗/斜体 *text*
Pattern.compile("~{2}(.*?)~{2}"), // 删除线 ~~text~~
Pattern.compile("^\\s*[-*+]\\s", Pattern.MULTILINE), // 无序列表项
Pattern.compile("^\\s*\\d+\\.\\s", Pattern.MULTILINE) // 有序列表项
};
public static String convertToText(String markdown) {
if (markdown == null || markdown.isEmpty()) return "";
// 逐步替换所有 Markdown 语法
String text = markdown;
for (Pattern pattern : MARKDOWN_PATTERNS) {
text = pattern.matcher(text).replaceAll("$1");
}
// 处理换行和多余空格
return text.trim()
www.chinasem.cn .replaceAll("\n{3,}", "\n\n") // 多个空行合并为两个
.replaceAll(" {2,}", " "); // 多个空格合并为一个
}
public static void main(String[] args) {
String md = "# Hello World!\n" +
"This is **bold** and *italic* text.\n" +
"[Link](https://example.com)";
System.out.println(convertToText(md));
/* 输出:
Hello World!
This is bold and italic text.
Link
*/
}
}
优点:零依赖、轻量快速
缺点:无法处理复杂嵌套结构
方法二:使用 Flexmark-java 库(专业方案)
推荐用于处理复杂 Markdown 文档
1. 添加依赖(Maven)
<dependency>
<groupId>com.vladsch.flexmark</groupId>
<artifactId>flexmark-all</artifactId>
<version>0.64.8</version>
</dependency>
运行 html
2. 转换代码实现
import com.vladsch.flexmark.ast.Node; import com.vladsch.flexmark.ext.gfm.tables.TablesExtension; import com.vladsch.flexmark.html.HtmlRenderer; import com.vladsch.flexmark.parser.Parser; import com.vladsch.flexmark.util.data.MutableDataSet; import org.jsoup.Jsoup; import java.util.Arrays; public class MarkdownToTextPro { public static String convert(String markdowngSUYPGLesy) { if (markdown == null || markdown.isEmpty()) return ""; // 配置解析器(支持表格等扩展) MutableDataSet options = new MutableDataSet(); options.set(Parser.EXTENSIONS, Arrays.asList(TablesExtension.create())); // 构建解析器和渲染器 Parser parser = Parser.builder(options).build(); HtmlRenderer renderer = HtmlRenderer.builder(options).build(); // 将 MarkdowChina编程n 解析为 HTML Node document = parser.parse(markdown); String html = renderer.render(document); // 使用 JSoup 去除 HTML 标签 return Jsoup.parse(html).text() .replaceAll("\\s+", " ") // 合并多余空格 .trim(); } public static void main(String[] args) { String md = "| Tables | 编程Are | Cool |\n" + "|----------|:-------------:|------:|\n" + "| col 1 is | left-aligned | $1600 |\n" + "| col 2 is | centered | $12 |"; System.out.println(convert(md)); /* 输出: Tables Are Cool col 1 is left-aligned $1600 col 2 is centered $12 */ } }
优点:
- 准确处理复杂结构(表格、嵌套列表等)
- 保留内容逻辑顺序
- 支持 Markdown 扩展语法
方案对比
| 特性 | 正则方案 | Flexmark 方案 |
|---|---|---|
| 依赖项 | 无 | 需要引入 JAR |
| 处理速度 | 极快 | 较快 |
| 语法支持 | 基础语法 | 完整语法+扩展 |
| 代码复杂度 | 简单 | 中等 |
| 处理嵌套结构能力 | 有限 | 优秀 |
| 输出可读性 | 一般 | 优秀 |
使用建议
简单内容处理:如果只需要处理标题、链接等基础语法,选择正则方案
复杂文档转换:如果需要处理表格、代码块、数学公式等复杂内容,使用 Flexmark 方案
保留格式结构:若需要保留段落换行等格式,可调整正则方案中的换行处理逻辑
对于需要更高精度的转换,可以结合两种方法:先用 Flexmark 转换,再通过正则处理特殊字符。
到此这篇关于Java实现将Markdown转换为纯文本的文章就介绍到这了,更多相关Java Markdown转纯文本内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!
这篇关于Java实现将Markdown转换为纯文本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!