在 NodeJS 中,什么是一种简洁、健壮、优雅的方式来最多读取文件的前 N 个字节?
- 如果数据较少,那么我不希望抛出错误。
- 如果有更多数据,那么我不希望将其读入内存。
理想情况下无需安装外部包。可能涉及自 NodeJS 12 以来似乎是新的(非实验性的)异步迭代器?
奖励:如何读取前 N 个字符,提供特定的编解码器(例如 utf-8
)?
编辑:根据我的互联网研究,这个确实相当基本的问题的答案远非显而易见,这就是我问的原因。我知道如何在其他语言环境中执行此操作,而且我是 NodeJS 生态系统的新手。
最佳答案
我在 NodeJS 12(使用 TypeScript)中使用以下方法已有一段时间了:
async function readFirstNBytes(path: fs.PathLike, n: number): Promise<Buffer> {
const chunks = [];
for await (let chunk of fs.createReadStream(path, { start: 0, end: n })) {
chunks.push(chunk);
}
return Buffer.concat(chunks);
}
关于node.js - Node : how to read (at most) the first N bytes from a file?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58985876/