当前位置: 首页 > news >正文

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("!\\[.*?\\]\\(.*?\\)"),      // 图片 ![alt](url)
        Pattern.compile("`{3,}[\\s\\S]*?`{3,}"),     // 代码块 ```code```
        Pattern.compile("`(.+?)`"),                 // 行内代码 `code`
        Pattern.compile("^[#]{1,6}\\s*"),            // 标题 # ## ###
        Pattern.compile("\\*{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()
                .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)

xml

复制

<dependency>
    <groupId>com.vladsch.flexmark</groupId>
    <artifactId>flexmark-all</artifactId>
    <version>0.64.8</version>
</dependency>

运行 HTML

2. 转换代码实现

java

复制

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 markdown) {
        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();

        // 将 Markdown 解析为 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
处理速度极快较快
语法支持基础语法完整语法+扩展
代码复杂度简单中等
处理嵌套结构能力有限优秀
输出可读性一般优秀

使用建议

  1. 简单内容处理:如果只需要处理标题、链接等基础语法,选择正则方案
  2. 复杂文档转换:如果需要处理表格、代码块、数学公式等复杂内容,使用 Flexmark 方案
  3. 保留格式结构:若需要保留段落换行等格式,可调整正则方案中的换行处理逻辑

对于需要更高精度的转换,可以结合两种方法:先用 Flexmark 转换,再通过正则处理特殊字符。

相关文章:

  • Python跳动的爱心
  • go数据结构笔记
  • Spring(5)——IoC DI
  • DevExpress WinForms 中 SwiftPlot 图表控件的使用指南
  • DeepSeek:技术教育领域的AI变革者——从理论到实践的全面解析
  • 修改 Macbook 终端窗口的显示信息
  • 【算法】用“龟兔赛跑”的思想原地移除元素
  • Go Context包详解与最佳实践
  • Vue学习笔记集--六大指令
  • f-string高级字符串格式化与string Template()
  • NestJS(基于 Express 的现代化框架)
  • coze ai assistant Task 3
  • 主流区块链
  • 人工智能在现代科技中的应用和未来发展趋势。
  • 每日Attention学习27——Patch-based Graph Reasoning
  • 来自腾讯的:《详解DeepSeek:模型训练、优化及数据处理的技术精髓》
  • 3.16学习总结
  • C#开发笔记:INI文件操作
  • 三、重学C++—CPP基础
  • Tsfresh + TA-Lib + LightGBM :A 股市场量化投资策略实战入门
  • 国铁集团:5月1日全国铁路预计发送旅客2250万人次
  • 中国空间站多项太空实验已取得成果,未来将陆续开展千余项研究
  • 关于“十五五”,在上海召开的这场座谈会释放最新信号
  • 陕西省副省长窦敬丽已任宁夏回族自治区党委常委、统战部部长
  • 北京银行一季度净赚超76亿降逾2%,不良贷款率微降
  • 新质观察|重塑低空经济的系统安全观