gpt4 book ai didi

java - 使用 FilterInputStream 删除 InputStream 的剩余部分

转载 作者:行者123 更新时间:2023-12-01 14:33:57 26 4
gpt4 key购买 nike

我计划使用 Java 处理 Markdown 文本文件,这些文件在文档开头以 YAML 格式指定附加元信息,如标题、作者、创建日期等。这是一个例子:

---
title: An example document
author: Paul
created: 2013-05-19
---

The _body_ of this document is
written in **Markdown**.

为了解析 YAML 数据,我可以使用 snakeyaml 。据我所知,您可以从 java.io.InputStreamjava.io.ReaderString 加载 YAML 文档通过方法 yaml.load()yaml.loadAll() (参见 the SnakeYAML documentationAPI )。

我不想使用从String读取的版本,因为这会导致大文件的性能问题。但是将文件作为 InputStream 处理会失败,因为该流不代表有效的 YAML 文档。只有流的第一部分代表有效文档。

所以我的问题是:如何使用 java.io.FilterInputStream/java.io.FilterReader 或其他方法生成流,该流在第二个之后停止--- 所以整个流是有效的 YAML?

最佳答案

在您希望 YAML 解析器停止的位置添加“...”(三个点)。

关于java - 使用 FilterInputStream 删除 InputStream 的剩余部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16636787/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com