使用 fast-csv 将写入附加到 csv 文件

Chr*_*ris 1 csv node.js express

我下面的函数读取accounts.csv,但是,我希望能够在其中写入。每次我执行 fs.createWriteStream 时,它都会覆盖整个文件并替换它。这是我的代码。我想附加结果

let stream = fs.createReadStream("accounts.csv");

fast
    .fromStream(stream, {headers : ["Account",
        "OrgName", "Contact1", "Contact2", "AddrLine1",
        "AddrLine2", "City", "State", "ZipPostal", "Country",
        "AccountType", "ACCTTYPE", "Partner", "PTRDATE", "LSTCONTD",
        "LSTGIFTDT", "LSTGIFTAmt"]})
    .on("data", function(data){
      var orgName = data
      console.log(data);
    })
    .on("end", function(){
      console.log("done");
    });


let ws = fs.createWriteStream('accounts.csv');

fast.
    write([

        {r: "r1", s:"s1"}

    ], {headers:true})
        .pipe(ws);
Run Code Online (Sandbox Code Playgroud)

Mar*_*nde 7

的默认标志fs.createWriteStreamw,它将打开文件进行写入,如果文件不存在则创建它,如果存在则截断它。

您需要使用a标志,它会打开文件进行追加。

let ws = fs.createWriteStream('accounts.csv', { flag: 'a' });
Run Code Online (Sandbox Code Playgroud)

请记住,您可能应该等到文件被读取,或者在读取之前追加。


mus*_*una 6

let ws = fs.createWriteStream('accounts.csv', { flags: 'a' });
Run Code Online (Sandbox Code Playgroud)

flag 关键字现在可能已经过时了。文档提到它必须“标记”。

fs.createWriteStream(路径, [选项])