开发者

Java实现将Markdown转换为纯文本

目录
  • 方法一:使用正则表达式(轻量级方案)
  • 方法二:使用 Flexmark-Java 库(专业方案)
    • 1. 添加依赖(Maven)
    • 2. 转换代码实现
  • 方案对比
    • 使用建议

      以下是两种在 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.devze.com        .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();
      
              // 将 Markdow编程客栈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转纯文本内容请搜索编程客栈(www.devze.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程客栈(www.devze.com)!

      0

      上一篇:

      下一篇:

      精彩评论

      暂无评论...
      验证码 换一张
      取 消

      最新开发

      开发排行榜