NodeJS:如何从文件中读取(最多)前 N 个字节?

Jan*_*cke 3 file node.js

在 NodeJS 中,从文件中最多读取前 N 个字节的简洁、健壮且优雅的方法是什么?

  • 如果数据较少,那么我不希望抛出错误。
  • 如果有更多数据,那么我不希望将其读入内存。

理想情况下无需安装外部软件包。也许涉及自 NodeJS 12 以来似乎是新的(非实验性的)异步迭代器?

奖励:如何读取前 N 个字符,提供特定的编解码器(例如utf-8)?

编辑:根据我的互联网研究,这个确实相当基本的问题的答案远非显而易见,这就是我问的原因。我知道如何在其他语言环境中执行此操作,并且我是 NodeJS 生态系统的新手。

Jan*_*cke 7

我在 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-1 })) {
    chunks.push(chunk);
  }
  return Buffer.concat(chunks);
}
Run Code Online (Sandbox Code Playgroud)

  • 请注意,“end”是包容性的,因此“{ start: 0, end: n }”会导致读取前“n+1”字节,而不仅仅是前“n”字节。https://nodejs.org/docs/latest-v18.x/api/fs.html#fscreatereadstreampath-options (2认同)