JSON 数据格式化方法

文章目录

    • 数据介绍
    • IDE 或脚本格式化
    • 在线工具网址
    • 总结

数据介绍

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于JavaScript 编程语言的一个子集。尽管它起源于 JavaScript,但 JSON 已经成为了一个完全独立于语言的文本格式,被广泛采用和应用于多种编程语境中。

JSON由道格拉斯·克罗克福特在1999年设计并提出。它是一个简化版的数据传输格式,其设计初衷是为了使得不同的网络应用程序可以轻易地交换数据。随着时间的推移,JSON逐渐演变成了一种主流的数据格式,并被许多现代编程语言所支持。

JSON的语法建立在两种结构之上:键值对的集合(类似于 Python 中的字典或 Objective C 中的对象)以及有序值列表(类似于数组)。JSON 数据可以是一个简单的值、一个数组、一个对象或者一个对象和数组的组合。下面是这些数据结构的详细描述:

  • 简单值: JSON中的简单值指的是字符串、数字、布尔值(true或false)和null。

  • 数组: 数组是值的有序集合,以方括号[]包围并以逗号,分隔。例如:[1, "apple", true]

  • 对象: 对象是键值对的无序集合,以花括号{}包围并以逗号,分隔。键和值之间使用冒号:分隔,并且键必须是字符串。例如:{"name": "John", "age": 30}

JSON数据格式具有以下特点:

  • 可读性强: JSON数据以人类可读的纯文本格式组织,这使得它即使在不借助任何工具的情况下也易于理解和编辑。

  • 易于解析生成: 几乎所有现代编程语言都提供了处理JSON数据的库或内置功能,使得从代码中生成JSON数据或解析JSON数据变得非常便捷。

  • 跨语言兼容: 作为一种通用的数据格式,JSON没有绑定到特定的编程语言,这意味着在不同编程环境之间交换数据时,JSON是一个很好的选择。

  • 数据描述能力强: JSON能够描述复杂的数据结构,包括嵌套的对象和数组,这使其成为表示层次化数据的理想选择。

JSON 与 XML 和 YAML 数据格式比较:

  • XML(Extensible Markup Language)是Web上数据交换的主要格式。然而,JSON 比 XML 更简洁,因为它不需要结束标签,数据更加紧凑。此外,JSON 直接映射到编程语言中的数据结构,如字典或哈希表,而XML则需要解析为这些数据结构。
  • YAML(Yet Another Markup Language)是另一种用于数据序列化的格式,它注重于人类的可读性和可写性。虽然YAML在某些情况下更易读写,但它的语法更复杂,有时可能会导致解析错误。相比之下,JSON的语法简单且不容易引起错误。

JSON(JavaScript Object Notation)是一种常用的数据交换格式,它以简洁、易读的方式存储和传输数据。在处理 JSON 数据时,数据格式化是一个重要的步骤,可以提高数据的可读性和可维护性。本文将介绍 JSON 数据格式化的方法,并提供两个在线工具网址,帮助您在处理 JSON 数据时进行格式化。

JSON 数据广泛应用于 Web 开发、移动应用开发、数据存储等领域。以下是一个示例 JSON 数据:

{"name": "John Doe","age": 30,"email": "johndoe@example.com","hobbies": ["reading","gaming","traveling"],"address": {"street": "123 Main Street","city":"New York","state": "NY"}}

目标,格式化 JSON 如下:

{
    "name": "John Doe",
    "age": 30,
    "email": "johndoe@example.com",
    "hobbies": [
        "reading",
        "gaming",
        "traveling"
    ],
    "address"{
        "street": "123 Main Street",
        "city": "New York",
        "state": "NY"
    }
}

那么,它可能会很难阅读和理解。这就是我们需要格式化 JSON 数据的原因。

IDE 或脚本格式化

许多集成开发环境(IDE)如 Visual Studio Code,PyCharm 等都有内置的 JSON 格式化功能。你只需要将你的 JSON 数据粘贴到编辑器中,然后使用相关的格式化命令或快捷键即可。下面是一些常见的 IDE 和脚本语言的 JSON 格式化方法:

  • Visual Studio Code(VS Code)是一款流行的免费代码编辑器,支持多种编程语言并且通过插件系统提供丰富的功能扩展。对于 JSON 数据,VS Code 内置了直观的格式化工具。要使用这个工具,只需打开一个 JSON 文件,然后按下 Ctrl+Shift+I(Windows/Linux)或 Cmd+Shift+I(Mac)快捷键。编辑器会自动按照标准的缩进规则重新格式化整个文档,使数据结构一目了然。
  • 对于 Java 开发者来说,IntelliJ IDEA 无疑是一款强大的 IDE。除了对 Java 的出色支持外,它也提供了处理 JSON 数据的功能。你可以打开一个 JSON 文件,然后使用 Code > Reformat Code 菜单项或者快捷键 Ctrl+Alt+L(Windows/Linux)/ Cmd+Alt+L(Mac)来快速格式化。IntelliJ IDEA 还会在编辑时提供实时的 JSON 验证和提示,帮助避免语法错误。
  • Sublime Text 是另一款广受欢迎的文本编辑器,以其速度和灵活性著称。虽然 Sublime Text 本身并不直接支持 JSON 格式化,但你可以通过安装插件来实现这一功能。例如,安装 Package Control 之后,你可以添加 JSONFormat 插件。通过 Edit > Line > Reindent 菜单项或者快捷键 Ctrl+Shift+R(Windows/Linux)/ Cmd+Shift+R(Mac),你可以很方便地对选定的 JSON 代码进行格式化。
  • PyCharm IDE 为开发者提供了一组快捷键来优化和加速开发流程,其中就包括用于代码格式化的快捷键。对于 JSON 数据,可以通过按下组合键 Ctrl+Alt+L 或者 Command+Option+L 来实现格式化。这种方法简单快捷,无需任何额外的配置或插件安装,是 PyCharm 内置功能的一部分。需要注意的是有时自定义的快捷键可能与 PyCharm 默认或其他插件的快捷键冲突。在这种情况下,需要调整快捷键设置,以避免操作上的混淆。

Python:使用 Python 的 json 模块可以轻松地格式化 JSON 数据。可以使用 json.dumps(data, indent=4) 方法将 JSON 对象转换为格式化后的字符串。

import json

data = {"name": "John Doe","age": 30,"email": "johndoe@example.com","hobbies": ["reading","gaming","traveling"],"address": {"street": "123 Main Street","city":"New York","state": "NY"}}

formatted_data = json.dumps(data, indent=4)
print(formatted_data)

JavaScript:在 JavaScript 中,可以使用 JSON.stringify(data, null, 2) 方法将 JSON 对象转换为格式化后的字符串,并指定缩进级别为 2。

const data = {"name": "John Doe","age": 30,"email": "johndoe@example.com","hobbies": ["reading","gaming","traveling"],"address": {"street": "123 Main Street","city":"New York","state": "NY"}};

const formattedData = JSON.stringify(data, null, 2);
console.log(formattedData);

Node.js:在Node.js环境下工作,可以利用其强大的文件系统模块(fs)来读取和写入JSON数据,同时结合JSON.stringify来实现数据的格式化。以下是一个示例代码:

const fs = require('fs');

// 读取原始 JSON 数据
fs.readFile('data.json', 'utf8', (err, data) => {
    if (err) {
        console.error(err);
        return;
    }

    // 解析并格式化 JSON 数据
    let jsonData;
    try {
        jsonData = JSON.parse(data);
    } catch (error) {
        console.error("Error parsing JSON:", error);
        return;
    }

    // 格式化 JSON 数据并写回文件
    const formattedData = JSON.stringify(jsonData, null, 4);
    fs.writeFile('formatted.json', formattedData, 'utf8', err => {
        if (err) console.error(err);
    });
});

解释:首先使用fs.readFile异步地读取一个名为data.json的文件。读取完成后,我们尝试使用JSON.parse将文件内容解析为一个JavaScript对象。然后我们使用JSON.stringify将这个对象格式化为一个美观的JSON字符串,并指定缩进为4个空格。最后,我们使用fs.writeFile将格式化后的字符串写回到一个新的文件formatted.json中。

IDE 或者脚本格式化 JSON,虽然能实现效果,但是没有直接点击来的快,接下来介绍两个好用的在线工具网址。

在线工具网址

如果您不想安装 IDE 或编写脚本来格式化 JSON 数据,可以使用在线工具进行 JSON 数据格式化。以下是两个提供 JSON 数据格式化功能的在线工具网址:

  • SO JSON 在线工具(https://www.sojson.com):SO JSON 在线工具是另一个提供 JSON 数据格式化功能的网站。它支持 JSON 数据的解析、格式化、压缩、转义、视图和编辑等功能。

image

  • JSONS 在线工具(http://www.jsons.cn):JSONS 是一个提供多种 JSON 相关工具的网站,其中包括 JSON 数据的在线解析、格式化、校验、压缩和转义等功能。

image

这个在线工具不仅可以格式化 JSON ,也可以格式化其他数据,如 HTML、SQL等,最好的功能是可以进行文本比较,在代码进行迁移对比差异时经常用到。示例如下,不一致的部分会直接标红色。

image

你只需要在这些网站上输入或粘贴你的 JSON 数据,它们就会自动为你格式化。

总结

JSON 数据格式化是处理 JSON 数据的重要步骤,有助于提高数据的可读性和可维护性。您可以使用 IDE 或脚本语言提供的内置功能进行格式化,也可以使用在线工具进行格式化。非常推荐 JSONS 不仅支持格式化,而且还支持代码文本对比和替换等功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/679656.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

杨校老师项目之SpringBoot整合Vue与微信小程序的外卖订餐系统

1.获取代码: 有偿获取:mryang511688 2.技术栈 SpringBoot MySQL mybatis Redis 微信小程序 摘 要 随着国内外卖行业的蓬勃发展,外卖平台间的竞争影响了许多餐饮企业。许多餐饮企业面临着第三方外卖平台抽佣高、营销策略受限等问题&am…

【Game】Powerful——Collection of Mystical Treasures(2)

参考来自: 非凡日常15|秘宝集解读第一版,玩法触发猜想! 关键词22|“探秘”、“秘宝集”,完整版 关键词22|“探秘”、“秘宝” 《神武4》百趣集探秘攻略 秘宝宝藏触发条件 文章目录 规则普通秘宝特殊秘宝新增秘宝 规则 基础次…

SmartEDA:电子设计新手进阶宝典,轻松开启创意之旅

在科技日新月异的今天,电子设计已成为众多创新者和工程师们展示才华的重要舞台。然而,对于初学者来说,电子设计的世界往往显得既神秘又复杂。幸运的是,有了SmartEDA这样的强大工具,新手也能轻松入门,逐步精…

i.MX8MP平台开发分享(MU功能介绍篇)

消息传递单元(MU)模块通过 MU 接口传递消息(如数据、状态和控制),使 SoC 中的两个处理器能够进行通信和协调。MU 还能让一个处理器使用中断向另一个处理器发出信号。 由于 MU 管理处理器之间的信息传递,因…

spring boot 2.1 集成activiti 6.0.0和activiti-modeler 5.23.0可视化编辑器(随记)

先上pom&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.or…

【WRF理论第二期】模型目录介绍

WRF理论第二期&#xff1a;模型目录介绍 1 WRF主目录2 WPS主目录3 编译后的可执行文件4 运行目录参考 了解 WRF 模型的目录结构有助于有效地管理和操作模型&#xff0c;从而确保模拟和分析工作的顺利进行。以下分解介绍WRF主目录、WPS主目录等。 Github-wrf-model/WRF 1 WRF…

小程序CI/CD之自动化打包预览并钉钉通知发布进程

小程序打包方式分为两种&#xff1a;手动打包、自动打包 那如何实现 自动打包 呐&#xff1f;我们今天就来聊一聊&#xff01; 首先&#xff0c;很重要&#xff0c;看 官方文档 这里提到今天我们要聊的“主角” miniprogram-ci miniprogram-ci 是从微信开发者工具中抽离的关于…

Day06 创建首页ListBox列表数据

​ 完成当前章节后,最终效果图如下 ​​​​ 一.首页汇总方块鼠标悬停阴影效果设计 首先,在上一章节首页设计 的时候,就已经知道当前主界面的汇总方块是使用 Border 来实现的,那么想要实现鼠标悬停时设置阴影的效果,就要在 Border 中进行重写样式。 需要使用 触发器 来实…

OrangePi Kunpeng Pro套装测评:开箱与基本功能测试

前言 大家好&#xff0c;我是起个网名真难。非常荣幸受到香橙派的邀请&#xff0c;同时也是第一次做这个事情&#xff0c;很荣幸对香橙派与华为鲲鹏在2024年5月12日联合发布的新品——香橙派Kunpeng Pro开发板进行深入的评测。这款开发板是香橙派与华为鲲鹏合作推出的高性能平…

企业微信应用 应用号内消息链接无法在企微内置浏览器打开 windows PC客户端 问题解决

问题 需求是每周在企微的应用号上发送周报&#xff0c;周报中会带着进入系统的链接&#xff0c;点击进入可以查看详情。系统需要登录鉴权&#xff0c;因此需要在内置浏览器打开便于自动认证。 但是&#xff0c;在企微应用号发送的链接&#xff0c;手机上可以正常使用企微内置…

E. 矩阵第k大

看到这句话&#xff0c;其中任意两个数都不能在同一行或者同一列 经典的网络流/匈牙利 由于小白看不懂网络流 &#xff08;其实是我不会&#xff09; &#xff0c;不妨就讲讲匈牙利 匈牙利算法 前置知识&#xff1a; 二分图 匈牙利&#xff08;是个人&#xff09;算法是二分…

OrangePi Ai Pro 开箱及镜像烧录指南

板子开箱 参加活动获得了香橙派与华为联合开发的 OrangePi AI Pro 开发板&#xff0c;这款开发板采用了华为自研的处理器&#xff0c;具有8TOPS的AI算力&#xff0c;可以满足一部分的AI开发需求&#xff0c;让 AI 开发不仅仅限于使用英伟达。 官方也是非常的大气&#xff0c;这…

【SQL边干边学系列】02介绍性问题(续)

文章目录 前言回顾介绍性问题7.产品名称中包含“queso”的产品8.运往法国或比利时的订单9.运往拉丁美洲任何国家的订单10.员工&#xff0c;按年龄的顺序排列11.让DateTime列仅显示Date12.员工全名13.每个订单的详细金额14.有多少客户&#xff1f;15.第一个订单是什么时候&#…

程序调试

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在程序开发过程中&#xff0c;免不了会出现一些错误&#xff0c;有语法方面的&#xff0c;也有逻辑方面的。对于语法方面的比较好检测&#xff0c;因…

积累常用css

1、封面文字&#xff0c;垂直居中&#xff0c;可以两列并排 2、宽border效果 .dashed-box { margin: 80px 0 40px 0;width: 100%;display: inline-block;background-image: linear-gradient(to right, #979797 65%, rgba(255, 255, 255, 0) 20%);background-position: bottom;…

yangwebrtc x86_64环境搭建

版本&#xff1a;5.0.099 sudo apt-get install libxext-dev sudo apt-get install x11proto-xext-dev sudo apt-get install libxi-dev sudo apt install libasound2-dev sudo apt install libgl1-mesa-dev sudo apt-get install libxtst-dev 用qt打开以下两个项目的.pro met…

性价比之战,小米、希喂、霍尼韦尔三款宠物空气净化器真实测评!

怨种闺蜜跟我吐槽&#xff0c;养猫之后家里面的空气质量变得越来越糟糕&#xff0c;空气中的浮毛和便臭严重影响到了居家舒适度&#xff0c;怀念没有养猫时清新的空气。 又想养猫&#xff0c;又不想生活在糟糕的环境中。使用了一些粘毛器和吸毛器都只能对付表面看得见的一些大…

BI平台概述

随着数字化浪潮的推进&#xff0c;企业对于数据驱动决策的需求日益增长。纷享销客作为一款领先的CRM平台&#xff0c;一直致力于帮助企业实现销售管理的高效与智能。纷享销客一体化BI智能分析平台作为CRM平台中的重要一环&#xff0c;旨在为企业提供更加全面、深入的数据分析能…

CDN(Content Delivery Network)内容分发网络原理、组成、访问过程、动静态加速、作用详解

CDN简介 什么是CND CDN&#xff08;Content Delivery Network&#xff09;的缩写&#xff0c;是一种利用分布式节点技术&#xff0c;在全球部署服务器&#xff0c;即时地将网站、应用视频、音频等静态或动态资源内容分发到用户所在的最近节点&#xff0c;提高用户访问这些内容…

opencv 在飞行堡垒8中调用camera导致设备消失

简介 使用 OpenCV 库时, 在最后调用cv::destroyAllWindows()之后设备管理器中的摄像头设备消失了&#xff0c; 看看是怎么触发的&#xff0c; 后面再慢慢研究RootCause是什么。 步骤 设备管理器原来摄像头显示 1. 代码 main.cpp Note: 1. haarcascade_frontalface_default…