热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何使用Node.js在JSON文件中添加数据?

如何使用Node.js在JSON文件中添加数据?原文:h

如何使用 Node.js 在 JSON 文件中添加数据?

原文:https://www . geesforgeks . org/how-add-data-in-JSON-file-use-node-js/

【JSON】代表 Javascript 对象符号。它是应用程序之间交换信息最简单的方式之一,通常被网站/应用程序接口用来通信。关于 Node.js 的入门,请参考这篇文章。

首先,您需要确保您期望的 JSON 文件不会消耗大量内存。对于估计消耗约 500 兆字节的数据,这种方法效率不高,您应该考虑使用数据库系统。


  1. Node.js 有一个名为 fs 的内置模块,它代表文件系统,使用户能够以建模的方式与文件系统交互。要使用它,请在服务器程序中键入下面的代码。

    js
    const fs = require('fs');

    fs 模块的文档可以在 这里 找到。


  2. 我们可以从创建一个 JSON 文件开始,对于这个例子,它将包含一个 id、一个名字和一个城市。请注意,您可以拥有任意多的键值对,但是我们首先使用三个。

    js
    {
    "id": 1,
    "name": "John",
    "city": "London"
    }

    让我们将这个 JSON 文件命名为 data.json。
    3. 现在我们有了一个可以写入的 JSON 文件,首先我们将创建一个 Javascript 对象来访问该文件。为此,我们将使用fs . readfilesync(),它将为我们提供原始格式的数据。为了得到 JSON 格式的数据,我们将使用 JSON.parse() 。因此,我们服务器端的代码如下所示:

    js
    var data = fs.readFileSync('data.json');
    var myObject= JSON.parse(data);


  3. 现在我们已经准备好了对象,让我们假设我们有一个要添加的键值对数据:

    js
    let newData = {
    "country": "England"
    }

    我们需要使用我们的对象(即 myObject)来添加这些数据。我们将通过使用。push()方法如下:

    js
    myObject.push(newData);


  4. 要将新数据写入我们的 JSON 文件,我们将使用 fs.writeFile() ,它将 JSON 文件和要添加的数据作为参数。请注意,在写入对象之前,我们必须先将它转换回原始格式。这将使用 JSON.stringify() 方法来完成。

    ```js
    var newData = JSON.stringify(myObject);
    fs.writeFile('data.json', newData, err => {
    // error checking
    if(err) throw err;

    console.log("New data added");

    });
    ```

    现在,我们的 data.json 文件如下所示:

    js
    {
    "id": 1,
    "name": "John",
    "city": "London",
    "country": "England"
    }


示例:上面示例的 index.js 代码。

index.js

// Requiring fs module
const fs = require("fs");
// Storing the JSON format data in myObject
var data = fs.readFileSync("data.json");
var myObject = JSON.parse(data);
// Defining new data to be added
let newData = {
  country: "England",
};
// Adding the new data to our object
myObject.push(newData);
// Writing to our JSON file
var newData2 = JSON.stringify(myObject);
fs.writeFile("data2.json", newData2, (err) => {
  // Error checking
  if (err) throw err;
  console.log("New data added");
});

输出:


推荐阅读
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
author-avatar
mobiledu2502908793
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有