在 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-1 })) {
chunks.push(chunk);
}
return Buffer.concat(chunks);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3090 次 |
| 最近记录: |