json数据格式说明
格式说明
- json文件由对象(集合)、数组、key/value元素组成,可以相互嵌套。
- 使用大括号包围的是对象,使用中括号包围的是数组,冒号分隔的是元素。
- 元素的key只能是字符串。
- 元素的value数据类型可以是:
- number:整数和浮点数都属于number类型,可以是正负数
- string:字符串
- bool:true/false
- array:使用中括号包围的部分是array
- object:使用大括号包围的是对象
- null:空。一般是这个值本来应该是某个object的,但是object不存在,于是为Null
- 对象、数组容器中每个元素之间使用逗号隔开,容器的最后一个元素不加逗号
- 顶级对象都是匿名的,也就是没有key
下面是一个json格式数据的示例:
{
"id":1,
"content":"hello world",
"author":{
"id":2,
"name":"userA"
},
"published":true,
"label":[],
"nextPost":null,
"comments":[
{
"id":3,
"content":"good post1",
"author":"userB"
},
{
"id":4,
"content":"good post2",
"author":"userC"
}
]
}
用注释分析这个json:
{ # 对象容器,下面全是这个对象中的属性。注意key全都是字符串
"id":1, # 文章ID号,元素,value类型为number
"content":"hello world", # 文章内容
"author":{ # 子对象,文章作者
"id":2, # 作者ID
"name":"userA" # 作者名称,注意子容器结束,没有逗号
},
"published":true, # 文章是否发布,布尔类型
"label":[], # 文章标签,没有给标签,所以空数组
"nextPost":null, # 下一篇文章,是对象,因为没有,所以为null
"comments":[ # 文章评论,因为可能有多条评论,每条评论都是一个对象结构
{ # 对象容器,表示评论对象
"id":3, # 评论的ID号
"content":"good post1", # 评论的内容
"author":"userB" # 评论者
},
{
"id":4,
"content":"good post2",
"author":"userC"
}
]
}
一般来说,json格式转换成语言中的数据结构时,有以下几个比较通用的规则(只是比较普通的方式,并非一定):
- json对象映射成语言中的hash/struct,有时候没有合适的结构,将映射成类。其实class、hash、struct在数据组织方式上都是一样的,都是key/value的容器
- json数组映射成语言中的列表/数组/切片
例如,上面的示例,转换成Go中的数据结构时,得到的结果如下:
// 使用名称A代替顶层的匿名对象
type A struct {
ID int64 `json:"id"`
Content string `json:"content"`
Author Author `json:"author"`
Published bool `json:"published"`
Label []interface{} `json:"label"`
NextPost interface{} `json:"nextPost"`
Comments []Comment `json:"comments"`
}
type Author struct {
ID int64 `json:"id"`
Name string `json:"name"`
}
type Comment struct {
ID int64 `json:"id"`
Content string `json:"content"`
Author string `json:"author"`
}
比如转换成python中的数据时,得到的结果如下:
from typing import List, Any
class Author:
id: int
name: str
def __init__(self, id: int, name: str) -> None:
self.id = id
self.name = name
class Comment:
id: int
content: str
author: str
def __init__(self, id: int, content: str, author: str) -> None:
self.id = id
self.content = content
self.author = author
# 使用了名称A代替顶层的匿名对象
class A:
id: int
content: str
author: Author
published: bool
label: List[Any]
next_post: None
comments: List[Comment]
def __init__(self, id: int, content: str, author: Author, published: bool, label: List[Any], next_post: None, comments: List[Comment]) -> None:
self.id = id
self.content = content
self.author = author
self.published = published
self.label = label
self.next_post = next_post
self.comments = comments
json转代码数据结构推荐工具
quicktype工具,可以轻松地将json文件转换成各种语言对应的数据结构。
在vscode中有相关插件
- 先在命令面板中输入"set quicktype target language"选择要将json转换成什么语言的数据结构
- 再输入"open quicktype for json"就可以将当前json文件转换对应的数据结构。
json数据格式说明的更多相关文章
- XML和JSON数据格式对比
概念 XML 扩展标记语言 (Extensible Markup Language, XML) ,用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语 ...
- VS快速生成JSON数据格式对应的实体
有固定好的Json数据格式,你还在手动敲对应的实体吗?有点low了!步入正题,这是一个json字符串,先去验证JSON数据格式(http://www.bejson.com/)如下: { & ...
- jQuery EasyUI:根据数据库内容生成适合于easyui-tree的JSON数据格式
1,jQuery EasyUI中easyui-tree特定的JSON数据格式 [ {"id":1,"text":"某公司","ch ...
- iOS 阶段学习第22天笔记(JSON数据格式介绍)
iOS学习(OC语言)知识点整理 一.JSON数据格式 1)概念:json是一种网络数据传输格式,有值/对象:{“A”:1,”B”:”2”…}词典:对象的序列:[,,,,,]数组两种数据类型 2)UR ...
- JS中将JSON的字符串解析成JSON数据格式《转》
在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式: 1.一种为使用eval()函数. 2. 使用Function对象来进行返回解析. 使用eval函数来解析,并且使用jquery的ea ...
- JSON 数据格式
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言.易于人阅读和编写,同时也易 ...
- JSON数据格式
JSON 数据格式 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.JSON采用完全独立于语言的文本格式,这些特性使JSON成为理想的数据交换语言.易于人 ...
- MVC返回JSON数据格式书写方式
返回json数据格式,多个返回值加,隔开 [Route("api/users/web")] //如果不加这个路由请这样调用:/api/users/web?schoolname=十五 ...
- VS中快速生成json数据格式对应的实体
JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度. JSON就是一串字符串 只不过元素会使用特定的符号标注. {} 双 ...
- (转)JSON数据格式和js操作json总结
原:http://niutuku.com/tech/javaScript/273643.shtml JSON数据格式和js操作json总结 来源:niutuku.com | vince ...
随机推荐
- 3、MHC主要组织相容性复合体
主要组织相容性复合体 (major histocompatibility complex MHC) 位于脊椎动物某对染色体上紧密连锁的基因群,其编码的蛋白是主要组织相容性抗原,是移植排斥反应的主要抗原 ...
- EasyUI 学习(1)-Tooltip(提示框)
一.创建组件 Tooltip不依赖其他组件 1.使用class加载 <a href="#" class="easyui-tooltip" title=&q ...
- 虚拟机安装+配置federa
安装 安装好后发现鼠标卡卡的,在虚拟机的显示设置里面启用3D加速: 配置 查看 显卡信息:lspci |grep VGA 测试显卡驱动:glxgears 安装必要软件 安装右键打开终端:sudo yu ...
- Nginx 教程(1):基本概念
简介 嗨!分享就是关心!所以,我们愿意再跟你分享一点点知识.我们准备了这个划分为三节的<Nginx教程>.如果你对 Nginx 已经有所了解,或者你希望了解更多,这个教程将会对你非常有帮助 ...
- web专业课学习及往后方向发展
日常10点起床!!!! web主要是网页设计,目前自我方向是学习web前端开发,熟悉掌握相关的编辑应用已达到能设计出满意的网页,日后继续学习后端等 ,成为全栈工程师.
- 关于Selenium WebDriver的geckodriver
下载Selenium的最新版本地址:http://selenium-release.storage.googleapis.com/index.html 友情提示:如果一直下载不了,可能是浏览器与下载工 ...
- docker基础内容讲解
一.初识docker 1.1 LXC介绍 LXC为LinuX Container的简写.Linux Container容器是一种内核虚拟化技术,可以提供轻量级的虚拟化,以便隔离进程和资源,而且不需要提 ...
- 升讯威微信营销系统开发实践:(2)中控服务器的详细设计( 完整开源于 Github)
GitHub:https://github.com/iccb1013/Sheng.WeixinConstruction因为个人精力时间有限,不会再对现有代码进行更新维护,不过微信接口比较稳定,经测试至 ...
- SQL Server AlwaysOn搭建
标签:SQL SERVER/MSSQL SERVER/数据库/DBA/高性能解决方案 概述 环境: 域服务器:windows server 2008 R2 SP1,192.168.2.10 DNS:1 ...
- 仿今日头条app手机端顶部触屏滑动导航
swiper.js <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...