热门标签 | 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");
});

输出:


推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • 原文地址:https:www.cnblogs.combaoyipSpringBoot_YML.html1.在springboot中,有两种配置文件,一种 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 在springmvc框架中,前台ajax调用方法,对图片批量下载,如何弹出提示保存位置选框?Controller方法 ... [详细]
  • 本文介绍了如何使用Express App提供静态文件,同时提到了一些不需要使用的文件,如package.json和/.ssh/known_hosts,并解释了为什么app.get('*')无法捕获所有请求以及为什么app.use(express.static(__dirname))可能会提供不需要的文件。 ... [详细]
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社区 版权所有