Java实现将Markdown转换为纯文本

2025-03-18 01:50

本文主要是介绍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("!\\[.*?\\]\\(.*?\\)"),      // 图片 ![alt](url)
        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转换为纯文本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153804

相关文章

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali