Java创建markdown文件(一)

本文介绍了如何使用Java结合markdown4j库来创建Markdown文件。作者欧阳方超在探索过程中,发现并引入了markdown4j工具,通过创建TitleBlock和TableBlock等对象,构建Markdown文件并将其写入本地。代码示例展示了创建二级标题和表格的实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java创建markdown文件(一)

1、概述

大家好,我是欧阳方超。题图是一颗葡萄。
某天下午,我一如既往静静地坐在工位上,忽然得到一个任务,把某些内容以markdown为载体进行下载,之前要么是通过Word要么是通过Excel进行下载。markdown编辑器或者插件倒是用过一些,但是用Java直接创建markdown文件却是没有操作过。于是就探索了一下。

2、探索之旅

抱着“这类功能一定有人实现过”的心态,开始了搜索之旅。最终发现了这个工具——markdown4j,该工程在github上地址为https://github.com/mstao/markdown4j,其是txtmark(https://github.com/rjeschke/txtmark)工程的分支。

2.1、使用

在Java工程中引入markdown4j的依赖,如下:

<!-- https://mvnrepository.com/artifact/fun.mingshan/markdown4j -->
<dependency>
    <groupId>fun.mingshan</groupId>
    <artifactId>markdown4j</artifactId>
    <version>1.0</version>
</dependency>

代码实现思路,在markdown4j工具jar中,TitleBlock、CodeBlock、TableBlock等Block类型的Block类型的类,它们可以分别创建markdown文件中的代码块、表格块、标题块等内容,在创建Markdown(markdown4j中的类)对象过程中,将创建Block类型的对象依次加入进来,最后使用jar包中MdWriter类中的write()方法即可将markdown文件写到本地。以下是完整实现代码:

import fun.mingshan.markdown4j.Markdown;
import fun.mingshan.markdown4j.type.block.TableBlock;
import fun.mingshan.markdown4j.type.block.TitleBlock;
import fun.mingshan.markdown4j.writer.MdWriter;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;

public class MarkdownTest {
    public static void main(String[] args) {
        //标题Block
        TitleBlock secondLevelTitleParamDesc = TitleBlock.builder().level(TitleBlock.Level.SECOND).content("价格说明\n").build();

        //表格中的行
        ArrayList<TableBlock.TableRow> rows = new ArrayList<>();
        TableBlock.TableRow tableRowOne = new TableBlock.TableRow();
        TableBlock.TableRow tableRowTwo = new TableBlock.TableRow();
        tableRowOne.setRows(Arrays.asList("20", "促销", "仅限本月"));
        tableRowTwo.setRows(Arrays.asList("40", "促销", "限制本周"));
        rows.add(tableRowOne);
        rows.add(tableRowTwo);
        //表格标题
        TableBlock tableBlock = TableBlock.builder()
                .titles(Arrays.asList("价格", "说明", "备注"))
                .rows(rows)
                .build();

        //构建markdown文件
        Markdown markdown = Markdown.builder()
                .name("价目")
                .block(secondLevelTitleParamDesc)
                .block(tableBlock)
                .build();

        //文件写入到本地
        try {
            MdWriter.write(markdown);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

上述代码中,首先创建了一个二级标题——“价格说明”,需要说明的是我在标题后加了\n换行,否则理应出现在标题下方的内容却出现在了标题的右侧,也就是说没有换行,这就是加\n的原因,有其他更优雅办法的小伙伴可以在评论区留言交流;接着创建一个表格,包括第一行的表格标题以及下面两行的内容;然后使用链式写法构建markdown文件,包括给文档起名字发;最后把文件写到本地。

3、总结

markdown4j是在txtmark工程的基础上发展而来的;有没有其他创建markdown文件的方式,欢迎各位在评论区讨论。
我是欧阳方超,把事情做好了自然就有兴趣了,如果你喜欢我的文章,欢迎点赞、转发、评论加关注。

### 使用Java读取Markdown文件 为了实现通过Java程序读取并处理Markdown文件的功能,可以采用多种方法。种常见的方式是利用第三方库来解析和渲染Markdown内容。 #### 方法:使用CommonMark库解析Markdown文件 CommonMark是个遵循CommonMark规范的纯Java库,能够有效地解析Markdown文档。下面展示了个简单的例子,说明如何加载并显示Markdown文件的内容: ```java import org.commonmark.parser.Parser; import org.commonmark.renderer.html.HtmlRenderer; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; public class MarkdownReader { public static void main(String[] args) throws IOException { // 读取Markdown文件路径 String filePath = "./example.md"; // 将Markdown文件转换成字符串形式 byte[] encoded = Files.readAllBytes(Paths.get(filePath)); String content = new String(encoded); Parser parser = Parser.builder().build(); HtmlRenderer renderer = HtmlRenderer.builder().build(); // 解析并渲染Markdown文本到HTML格式 System.out.println(renderer.render(parser.parse(content))); } } ``` 这段代码首先定义了要打开的目标Markdown文件的位置`filePath`,接着把该文件中的数据作为字节数组读入内存,并将其解码为UTF-8编码下的字符串表示法。之后创建了解析器对象用于分析输入流中的Markdown语法结构;最后构建渲染器实例负责将这些抽象出来的节点树转化为最终可呈现的形式,在这里是以HTML标签组成的字符串输出[^1]。 #### 方法二:直接操作文件而不做任何特殊处理 如果不需要特别关注Markdown语法规则的应用场景下,则可以直接按照普通文本方式对待Markdown文件。此时只需简单调用标准I/O类即可完成基本的任务需求。 ```java import java.io.BufferedReader; import java.io.FileReader; import java.io.IOException; public class SimpleMarkdownFileReader { public static void main(String[] args) { try (BufferedReader br = new BufferedReader(new FileReader("./simple_example.md"))) { StringBuilder sb = new StringBuilder(); String line; while ((line = br.readLine()) != null) { sb.append(line); sb.append(System.lineSeparator()); } System.out.println(sb.toString()); } catch (IOException e) { e.printStackTrace(); } } } ``` 此段代码展示了另种更为基础的做法——逐行读取指定位置上的`.md`扩展名结尾的纯文本文件,并打印出来。这种方式适用于那些仅需获取原始字符序列而无需进步解释其含义的情况[^2]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值