JSON相关

json是国际通用语言,可以跨平台(游戏,软件,网页,不同OS)使用,

json语法较为简单,使用更广泛。json使用键值对来存储。

认识json文件

//注意字典类型存储时,键是以string类型存储的 需要添加“”

{
"name": "TonyChang",
"age":21,
"sex":true,
"Float": 2.5,
"arrarys":[1,5,9],
"friends": [{"name": "Tom","age":21, "sex":true,"Float": 2.8},
{"name": "Peter","age":17, "sex":true,"Float": 3.5},
{"name": "Jack","age":25, "sex":true,"Float": 5.0}
],
"university": {"address": "唐山","province":"河北"},
"dic": {"1":"125","2": 911},
"son": null
}

Excel转换为JSON文件:

使用网站来转换:bejson

挖坑-----》开发一个工具,使各种类型存储文件进行转换。

Json的读写:

  1. jsonUtlity中的使用:

    string jisonStr = JsonUtility.ToJson(_writer);
    File.WriteAllText(Application.persistentDataPath+"/DemoJson1.json",jisonStr);

    转储为JSON时要点:

    1. float存储时看起来会有一些误差
    2. 自定义类序列化要添加序列化特性[System.Serializable]
    3. 想要序列化私有变量,需要添加序列化特性[SerializeField]
    4. JsonUtility不支持字典
    5. JsonUtility存储对象时候不会为null是默认值的数值

完整的类

using System;
using System.Collections.Generic;
using System.IO;
using UnityEngine; namespace Building.JSON
{
public class Writer
{
public string name;
public int age;
public bool sex;
[SerializeField]
protected float numberF = 3.15f;
[SerializeField]
private double numberD = 6.15;
public List<int> Array;
public IDCard idcard;
} [Serializable]
public class IDCard
{
public int stu_id;
public int cl_id;
}
public class JsonPractice:MonoBehaviour
{
private Writer _writer; private void Awake()
{
_writer = new Writer();
_writer.name = "TonyCode";
_writer.sex = true;
_writer.age = 21;
_writer.Array = new List<int>() {1, 2, 3, 4, 5};
_writer.idcard = new IDCard();
_writer.idcard.cl_id = 256;
_writer.idcard.cl_id = 206;
string jisonStr = JsonUtility.ToJson(_writer);
File.WriteAllText(Application.persistentDataPath+"/DemoJson1.json",jisonStr);
print(Application.persistentDataPath);
}
}
}

存储生成的json文件内容。

反序列化:

string jsonStrRead = File.ReadAllText(Application.persistentDataPath + "/DemoJson1.json");
//反序列化
Writer writer01 = JsonUtility.FromJson<Writer>(jsonStrRead);
Writer writer02=JsonUtility.FromJson(jsonStrRead,typeof(Writer)) as Writer;

注意:使用JsonUtility.FromJson进行反序列化时候接受对象是一个对象,不能是一个数据集合来接受Json中存储的数据内容。并且json的编码格式必须为UTF-8。

JSON文件的写入与读取,本质是对text文本的读写,所以会调用File类中对text文本相关的方法。

先将类转换为string字符串(Json文件格式的字符串),然后调用文件方法进行读写。

2.LitJson(第三方开发的工具包)

 //使用LitJson存储
string jsonStr2=JsonMapper.ToJson(_writer);
File.WriteAllText(Application.persistentDataPath+"/DemoJson2.json",jsonStr);

注意:(区别JsonUtility)

  • 不能序列化private变量;
  • 对于自定义类不需要添加序列化特性就可以进行序列化;
  • 支持字典类型,建议字典类型的键的类型为“string”;
  • 可以准确保存null类型;
//使用LitJson读(反序列化)
string jsonStrRead3 = File.ReadAllText(Application.persistentDataPath + "/DemoJson2.json");
//方法一
JsonData data = JsonMapper.ToObject(jsonStrRead3);
print(data["name"]);
//方法二 (使用较多)
Writer writer03= JsonMapper.ToObject<Writer>(jsonStrRead3);

读取数据集合:

//数据集合中元素类型
public class RoleInfo
{
public int hp;
public int speed;
public int volume;
public string resName;
public int scale;
}
//读取数据集合
string jsonStrRoleList = File.ReadAllText(Application.persistentDataPath + "/RoleInfo.json");
List<RoleInfo> roleInfos = JsonMapper.ToObject<List<RoleInfo>>(jsonStrRoleList);
foreach (var roleInfo in roleInfos )
{
print(roleInfo.hp+" "+roleInfo.speed+" "+roleInfo.resName);
}

RoleInfo.json内容

[
{"hp":4,"speed":6,"volume":5,"resName":"Airplane/Airplane1","scale":15},
{"hp":3,"speed":7,"volume":4,"resName":"Airplane/Airplane2","scale":15},
{"hp":2,"speed":8,"volume":3,"resName":"Airplane/Airplane3","scale":15},
{"hp":10,"speed":3,"volume":10,"resName":"Airplane/Airplane4","scale":6},
{"hp":6,"speed":5,"volume":7,"resName":"Airplane/Airplane5","scale":10}
]

读取字典:

 //读取字典
//注意字典元素内容最后一个不应当添加逗号
string jsonStrDic = File.ReadAllText(Application.persistentDataPath + "/JsonDic.json");
Dictionary<string, int> games = JsonMapper.ToObject<Dictionary<string, int>>(jsonStrDic);
foreach (KeyValuePair<string,int> kv in games)
{
print(kv.Key+" "+kv.Value);
}

JsonDic.json中内容:

{
"Tony": 100,
"Jack": 125,
"Pony": 156,
"Tom": 126
}

注意:

  1. litJson支持字典存储,字典键的类型为string
  2. 自定义类结构一定要有无参构造函数
  3. LitJson可以直接读取数据集合
  4. LitJson读取字典元素时候 字典内容最后一个不可以加逗号(可能反序列化失败)

对比JsonUtility和JsonLit二者使用:

相同:

  1. 二者都是对json文件进行序列化与反序列化的工具类
  2. 二者都是静态调用,使用其中的方法
  3. json的格式必须为UTF-8格式

区别:LitJson对比JsonUtility

  1. 对于空对象,LitJson对可以存储null类型,而后者只存储对应的默认数据数据值
  2. LItJson支持数据集合的读取,而后者需要将其转换为对象内部的数组才可以读取,读取存储结果为对象类型,而非数据集类型。
  3. LitJson支持对字典的存取,字典的键的类型为string
  4. LitJson存储兹定于数据类型时候无需添加序列化特性,而后者需要
  5. LitJson不支持对priivate数据内容的序列化,后者使用时候添加序列化特性则可以完成存储
  6. LitJson要求自定义数据类型必须有无参构造,而JsonUtility则不需要

Json读存的工具类:

using System.IO;
using LitJson;
using UnityEngine; namespace Building.JSON
{
public enum SaveJsonType
{
JsonUtility,
LitJson
}
public class JsonManager
{
private static JsonManager instance=new JsonManager();
public static JsonManager Instance => instance; private JsonManager()
{ }
/// <summary>
/// 存储Json方法
/// </summary>
/// <param name="data">要存储的数据类</param>
/// <param name="FileName">存储文件名称</param>
/// <param name="type">存储方法</param>
public void SaveJson(object data, string FileName,SaveJsonType type=SaveJsonType.LitJson)
{
//确定路径
string path = Application.persistentDataPath + "/"+FileName+ ".json";
string jsonStr="";
switch (type)
{
case SaveJsonType.LitJson:
jsonStr = JsonMapper.ToJson(data);
break;
case SaveJsonType.JsonUtility:
jsonStr = JsonUtility.ToJson(data);
break;
}
//写入文件
File.WriteAllText(path,jsonStr);
} /// <summary>
/// 读取json方法
/// </summary>
/// <param name="FileName">读取json的名称</param>
/// <param name="type">读取方式</param>
/// <typeparam name="T">读取json文件中数据类型</typeparam>
/// <returns></returns>
public T LoadJson<T>(string FileName, SaveJsonType type = SaveJsonType.LitJson) where T : new()
{
//确定路径
string path = Application.persistentDataPath + "/"+FileName+ ".json";
if (!File.Exists(path))
{
path=Application.streamingAssetsPath+"/"+FileName+".json";
if (!File.Exists(path))
{
return new T();
}
}
string jsonStrRead=File.ReadAllText(path);
T data = default(T);
switch (type)
{
case SaveJsonType.LitJson:
data=JsonMapper.ToObject<T>(jsonStrRead);
break;
case SaveJsonType.JsonUtility:
data= JsonUtility.FromJson<T>(jsonStrRead);
break;
}
return data;
}
}
}

Unity学习笔记--数据持久化Json的更多相关文章

  1. tensorflow学习笔记——模型持久化的原理,将CKPT转为pb文件,使用pb模型预测

    由题目就可以看出,本节内容分为三部分,第一部分就是如何将训练好的模型持久化,并学习模型持久化的原理,第二部分就是如何将CKPT转化为pb文件,第三部分就是如何使用pb模型进行预测. 一,模型持久化 为 ...

  2. Adaptive AUTOSAR 学习笔记 15 - 持久化 Persistency

    本系列学习笔记基于 AUTOSAR Adaptive Platform 官方文档 R20-11 版本 AUTOSAR_EXP_PlatformDesign.pdf.作者:Zijian/TENG 原文地 ...

  3. Android学习笔记之Fast Json的使用

    PS:最近这两天发现了Fast Json 感觉实在是强大.. 学习内容: 1.什么是Fast Json 2.如何使用Fast Json 3.Fast Json的相关原理 4.Fast Json的优势, ...

  4. [学习笔记]可持久化数据结构——数组、并查集、平衡树、Trie树

    可持久化:支持查询历史版本和在历史版本上修改 可持久化数组 主席树做即可. [模板]可持久化数组(可持久化线段树/平衡树) 可持久化并查集 可持久化并查集 主席树做即可. 要按秩合并.(路径压缩每次建 ...

  5. PHP 开发 APP 接口 学习笔记与总结 - JSON 方式封装通信接口

    1.通信数据的标准格式 ( JSON ),包括: code:状态码(200,400等) message:提示信息(例如:数据返回成功.邮箱格式错误等) data:返回数据 2.JSON 方式封装通信接 ...

  6. iOS学习之数据持久化详解

    前言 持久存储是一种非易失性存储,在重启设备时也不会丢失数据.Cocoa框架提供了几种数据持久化机制: 1)属性列表: 2)对象归档: 3)iOS的嵌入式关系数据库SQLite3: 4)Core Da ...

  7. Android学习_数据持久化

    数据持久化:将内存中的瞬时数据存储到设备中 1. 文件存储 存储一些简单的文本数据或二进制数据. 核心:Context类提供的openFileOutput()和openFileInput()方法,然后 ...

  8. Docker 学习笔记(持久化数据的备份,还原)

    假如我们应用程序需要一台 mssql 数据库来持久化数据,我们将 mssql 数据库运行于 Docker 容器中: docker run -d -p 1433:1433 -e "ACCEPT ...

  9. 吴裕雄--天生自然python学习笔记:Python3 JSON 数据解析

    JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. Python3 中可以使用 json 模块来对 JSON 数据进 ...

  10. Android学习笔记_14_对JSON格式数据的处理

    public class ParseJsonTest extends AndroidTestCase{ public void testJson() throws Exception { String ...

随机推荐

  1. [转帖]clickHouse单机模式安装部署(RPM安装)

    关于版本和系统的选择 操作系统:Centos-7 ClickHouse: rpm 在安装,20.x 安装前的准备 CentOS7 打开文件数限 在 /etc/security/limits.conf ...

  2. [转帖]Chrome 109发布,最后一个支持Windows 7/8的版本

    https://www.163.com/dy/article/HQR3QQFD0511CUMI.html 出品 | OSC开源社区(ID:oschina2013) Google 在去年 12 月 1 ...

  3. Windows 和 linux 下面 Redis 性能比较

    Windows 和 linux 下面 Redis 性能比较 问题来源 公司里面有一些环境还是使用Windows来跑 对应的. Redis和nginx 也是跑在Windows上面 但是微软官网自从 3. ...

  4. [转帖]Elasticsearch 技术分析(七): Elasticsearch 的性能优化

    https://www.cnblogs.com/jajian/p/10176604.html 硬件选择# Elasticsearch(后文简称 ES)的基础是 Lucene,所有的索引和文档数据是存储 ...

  5. killall 以及 pkill 等命令

    https://zhidao.baidu.com/question/1500084252693125099.html // 通过 killall 命令killall nginx// 通过 pkill ...

  6. Charles的基本使用

    今天介绍Charles常用的几个功能 一.map local 1.map local是测试中mock数据常用的功能,首先我们选择需要mock数据的接口,这里以百度为例 抓包抓住该接口后鼠标右击选择ma ...

  7. Vue基础系统文章06---导入和导出

    一.导入和导出 如果想要在一个Js文件中用另一个js文件的代码 1.将js文件中的变量和函数导出 let a = "aaaa" function show() { console. ...

  8. 深度学习应用篇-元学习[15]:基于度量的元学习:SNAIL、RN、PN、MN

    深度学习应用篇-元学习[15]:基于度量的元学习:SNAIL.RN.PN.MN 1.Simple Neural Attentive Learner(SNAIL) 元学习可以被定义为一种序列到序列的问题 ...

  9. 19.0 Boost 基于ASIO网络编程技术

    Boost ASIO库是一个基于C++语言的开源网络编程库,该库提供了成熟.高效.跨平台的网络API接口,并同时支持同步与异步两种模式,ASIO库提供了多重I/O对象.异步定时器.可执行队列.信号操作 ...

  10. ::v-deep样式穿透

    //如果不加样式穿透,vue永远会在input后面加唯一样式字段data-v-1d9b105c //::v-deep拼在哪个位置,哪个位置就有唯一标识data-v-1d9b105c .divBox : ...