1. ホーム
  2. ジャバスクリプト

[解決済み】Node.jsでJSONファイルにデータを書き込む/追加する

2022-04-04 21:49:27

質問

ループデータからnodeを使ってJSONファイルを書きたいのですが、どうすればいいですか?

let jsonFile = require('jsonfile');

for (i = 0; i < 11; i++) {
    jsonFile.writeFile('loop.json', "id :" + i + " square :" + i * i);
}

loop.jsonのoutPutは。

id :1 square : 1

しかし、私は以下のような出力ファイルが欲しいです。また、このコードを再度実行すると、同じ既存のJSONファイルに要素としてその新しい出力を追加する必要があります。

{
   "table":[
      {
         "Id ":1,
         "square ":1
      },
      {
         "Id ":2,
         "square ":3
      },
      {
         "Id ":3,
         "square ":9
      },
      {
         "Id ":4,
         "square ":16
      },
      {
         "Id ":5,
         "square ":25
      },
      {
         "Id ":6,
         "square ":36
      },
      {
         "Id ":7,
         "square ":49
      },
      {
         "Id ":8,
         "square ":64
      },
      {
         "Id ":9,
         "square ":81
      },
      {
         "Id ":10,
         "square ":100
      }
   ]
}

1回目に作成したファイルと同じものを使いたいのですが、このコードを実行するたびに新しい要素がその同じファイルに追加されるはずです。

const fs = require('fs');

let obj = {
    table: []
};

fs.exists('myjsonfile.json', function(exists) {

    if (exists) {

        console.log("yes file exists");

        fs.readFile('myjsonfile.json', function readFileCallback(err, data) {

            if (err) {
                console.log(err);
            } else {
                obj = JSON.parse(data);

                for (i = 0; i < 5; i++) {
                    obj.table.push({
                        id: i,
                        square: i * i
                    });
                }

                let json = JSON.stringify(obj);
                fs.writeFile('myjsonfile.json', json);
            }
        });
    } else {

        console.log("file not exists");

        for (i = 0; i < 5; i++) {
            obj.table.push({
                id: i,
                square: i * i
            });
        }

        let json = JSON.stringify(obj);
        fs.writeFile('myjsonfile.json', json);
    }
});

解決方法は?

もし、このJSONファイルが時間とともに大きくならないのであれば、試してみるべきでしょう。

  1. テーブルの配列が入ったJavaScriptオブジェクトを作成する

    var obj = {
       table: []
    };
    
    
  2. データを追加する、など。

    obj.table.push({id: 1, square:2});
    
    
  3. でオブジェクトから文字列に変換します。 JSON.stringify

    var json = JSON.stringify(obj);
    
    
  4. fsを使用して、ファイルをディスクに書き込む

    var fs = require('fs');
    fs.writeFile('myjsonfile.json', json, 'utf8', callback);
    
    
  5. 追記する場合は、JSONファイルを読み込んで、オブジェクトに変換して戻します

    fs.readFile('myjsonfile.json', 'utf8', function readFileCallback(err, data){
        if (err){
            console.log(err);
        } else {
        obj = JSON.parse(data); //now it an object
        obj.table.push({id: 2, square:3}); //add some data
        json = JSON.stringify(obj); //convert it back to json
        fs.writeFile('myjsonfile.json', json, 'utf8', callback); // write it back 
    }});
    
    

これは、実質100MBまでのデータに対して有効です。この制限を超えると、データベースエンジンを使用する必要があります。

UPDATEしてください。

現在の日付(年+月+日)を文字列で返す関数を作成する。この文字列+.jsonという名前のファイルを作成する。fsモジュールには、fs.stat(path, callback)というファイルの存在を確認する関数がある。 これを使えば、ファイルが存在するかどうかを確認することができます。存在すればread関数を、存在しなければcreate関数を使用します。パスには日付の文字列を使います。ファイルが今日の日付 + .json という名前になるからです。