Java中富文本转markdown

2023-12-08 03:01
文章标签 java 文本 markdown 中富

本文主要是介绍Java中富文本转markdown,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现富文本即html语法转md,要求是尽可能展示效果一样,可以有少许误差,另外只实现了html中的body转md,其他标签如head等未实现。

大致思路是:通过jsoup工具获取html节点,再穷举替换。前提是熟悉html以及md语法

依赖如下:

        <dependency><groupId>org.jsoup</groupId><artifactId>jsoup</artifactId><version>1.16.1</version></dependency>

代码如下:

import lombok.Data;
import org.apache.commons.lang3.StringUtils;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;import java.util.ArrayList;
import java.util.List;public class Html2MarkdownUtil {public static void main(String[] args) {String html = "<p style=\"padding: 0; margin: 10px 0; line-height: 1.5; font-size: 16px;\"><b style=\"padding: 0; margin: 0;\">Hello<font color=\"#c24f4a\" style=\"padding: 0; margin: 0;\">world</font></b></p>";System.out.println(parseHtml2Markdown(html));}/*** 解析html2md** @param html html* @return {@link String}*/public static String parseHtml2Markdown(String html) {Document doc = Jsoup.parse(html);StringBuilder sb = new StringBuilder();for (Element element : doc.body().children()) {HtmlElement htmlElement = new HtmlElement(element);sb.append(htmlElement.getMarkdownText());}return sb.toString();}/*** 标记文本** @param element 要素* @return {@link String}*/public static String toMarkdownText(Element element) {StringBuilder sb = new StringBuilder();String tagName = element.tagName().toLowerCase();String text = element.ownText();switch (tagName) {case "h1":sb.append("# ").append(text);break;case "h2":sb.append("## ").append(text);break;case "h3":sb.append("### ").append(text);break;case "h4":sb.append("#### ").append(text);break;case "h5":sb.append("##### ").append(text);break;case "h6":sb.append("###### ").append(text);break;case "p":case "font":case "b":case "span":sb.append(text);break;case "ul":for (Element child : element.children()) {sb.append("* ").append(child.text().trim()).append("\n");}break;case "ol":int index = 1;for (Element child : element.children()) {sb.append(index).append(". ").append(child.text().trim()).append("\n");index++;}break;case "a":sb.append("[").append(text).append("](").append(element.attr("href")).append(")");break;case "strong":sb.append("**").append(text).append("**");break;case "em":sb.append("_").append(text).append("_");break;case "blockquote":sb.append("> ").append(text);break;case "img":sb.append("![");if (element.hasAttr("alt")) {sb.append(element.attr("alt"));}sb.append("](").append(element.attr("src")).append(")");break;default:break;}return sb.toString();}@Datapublic static class HtmlElement {private Element element;private String tagName;private String ownText;private boolean isNewline;private List<HtmlElement> children;public HtmlElement(Element element) {this.element = element;this.tagName = element.tagName().toLowerCase();this.ownText = element.ownText();this.isNewline = isNewline();if (!StringUtils.equalsAny(this.tagName, "ul", "ol")) {Elements children = element.children();if (children.size() > 0) {this.children = new ArrayList<>();for (Element child : children) {this.children.add(new HtmlElement(child));}}}}public boolean isNewline() {return StringUtils.equalsAny(tagName, "h1", "h2", "h3", "h4", "h5", "h6", "p", "ul", "ol", "blockquote");}public String getMarkdownText() {StringBuilder sb = new StringBuilder();sb.append(toMarkdownText(element));if (children != null && children.size() > 0) {for (HtmlElement child : children) {sb.append(child.getMarkdownText());}}if (isNewline) {sb.append("\n");}return sb.toString();}}
}

这篇关于Java中富文本转markdown的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringSecurity JWT基于令牌的无状态认证实现

《SpringSecurityJWT基于令牌的无状态认证实现》SpringSecurity中实现基于JWT的无状态认证是一种常见的做法,本文就来介绍一下SpringSecurityJWT基于令牌的无... 目录引言一、JWT基本原理与结构二、Spring Security JWT依赖配置三、JWT令牌生成与