node.js - Node : how to read (at most) the first N bytes from a file?

标签 node.js file

在 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/

相关文章:

node.js - Sequelize .update() 总是返回 [0]

node.js - Coveralls 显示 0% 的 node.js 项目覆盖率

javascript - Node 是有状态的吗? Node能否在内存中维护变量

windows - 如何将命令行指令本身转储到输出文件中?

Java:部分路径存在,文件的部分名称

java - 如何使用 Java 在 Windows 文件上设置 "modify"ACL

java - 如何使用 Java 将文件从一个文件夹复制到另一个文件夹?

javascript - Selenium (Node.js) 截屏速度太慢

javascript - 在express js中制作api时出现 "cannot get"错误

java - 如何从文本文件中删除第一个字符串和逗号