gpt4 book ai didi

node.js - child_process.execSync 返回的缓冲区不完整

转载 作者:搜寻专家 更新时间:2023-10-31 23:34:22 35 4
gpt4 key购买 nike

我有以下执行 shell 命令的脚本:

#!/usr/bin/env node

const { execSync } = require('child_process');

try {
const data = execSync(
'yarn licenses generate-disclaimer --prod',
{ encoding: 'utf8', maxBuffer: 50 * 1024 * 1024 }
);

console.log(data.length);

return true;
} catch (error) {
console.error(`Failed to generate disclaimer: ${error.message}`);
return false;
}

data 是一个包含子进程的 stdoutBuffer。据我了解,将其转换为字符串的方法是使用 .toString() 方法,但在我的例子中,字符串是不完整的。我尝试执行的命令应该会产生约 500 KB 的数据,但 buffer.length 是 43741(即约 43 KB)。

问题可能是 yarn licenses 输出包含一些特殊字符,导致缓冲区不完整。如果我用 printf "%0.s-"{1..500000} 替换命令,缓冲区就完成了。

我使用的是最新的 Node 版本 (8.7.0)。

有什么想法/建议吗?


编辑:附加 | tr "\0""\n" 命令将缓冲区大小增加到 ~122 KB,所以@YaroslavAdmin 肯定是在寻找正确的方向。结果仍然不完整。如何确保转义所有特殊字符?

最佳答案

在 execSync 之后添加 .toString()

const data = execSync(
'yarn licenses generate-disclaimer --prod',
{ encoding: 'utf8', maxBuffer: 50 * 1024 * 1024 }
).toString(); // <<<<<<<<<<<<

关于node.js - child_process.execSync 返回的缓冲区不完整,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46818563/

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