1.10 Unity中的数据存储 JSON

2024-01-11 08:28
文章标签 数据 json 存储 unity 1.10

本文主要是介绍1.10 Unity中的数据存储 JSON,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、介绍

  • Json是最常用也是目前用的比较多的一种,超轻量级,可便捷性使用,平时用到比较多的都是解析Json和往Json中添加数据、修改数据等等
  • JSON(JavaScript Object Notation,JS对象标记)是一种轻量级的数据交换格式,它基于ECMAScript(w3c制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率
  • 在Unity中大致有三种使用Json的方式
  • 分别是使用类库的两种:System.Json(便于JSON生成)和LitJson(便于JSON解析)
  • 还有一种是UnityEngine.Jsonutility
  • 其中前两种都需要将System.Json.dll或 LitJson.dll两个dll文件放到Unity的plugins文件夹中才能使用相应的命名空间和方法
  • UnityEngine.JsonUtility则可以直接使用其中的方法

二、语法规则

  • 数据都放置到一个大括号里
  • 一对对的数据放到大括号里
  • 一个个的数据放到中括号里
  • 一个大括号或一个中括号都可以表示一个值
  • 数据与数据之间用逗号分隔
  • Key必须要用引号引起来
  • Value如果是字符串要用引号引起来
  • 最后一个数据后面不要加逗号
  • 数据保存在键值对中

JSON语法示例:

{"students":[{"name":"albert","age":19,"sex":"M"},{"name":"mary","age":11,"sex":"W"}]
}

解析成实体类后:

public class StudentsItem
{public string name { get; set; }public int age { get; set; }public string sex { get; set; }
}public class Root
{public List <StudentsItem > students { get; set; }
}

由于Json对字符串的格式非常严格,输入一个字符错误都不行,所以我们可以使用相关的Json转换网站进行格式转换
https://www.json.cn/json2csharp.html 这个网站就可以实现JSON数据转实体的功能

三、System.Json

先来说一下System.Json的基本用法
System.Json是一种类库,当我们在Unity中导入System.Json.dll文件后就可以使用System.Json.dll json命名空间
可以用到的类:JsonArray、JsonObject、JsonPrimitive、JsorValue。枚举:JsonType
具体操作,在Unity中新建一个Plugins文件夹,然后将dll文件放入即可

四、示例

using System.Json;
using UnityEngine;public class JsonTest : MonoBehaviour
{void Start(){//创建⼀个JSON对象,相当于⼀个⼤括号JsonObject jsonTransform = new JsonObject();//创建⼀个JSON值对象,存储⼀个ValueJsonValue jsonPosition = "10,20,30";//JSON对象,也就是⼤括号,添加⼀个key:valuejsonTransform.Add("position", jsonPosition);//打印结果Debug.Log(jsonTransform.ToString());//定义⼀个值数组,⽤来存储,中括号中的⼀个个的值JsonValue[] rotationXYZ = new JsonValue[] { 20, 30, 40 };//将这个数组中的⼀个个的值放到JsonArray数组对象中JsonArray jsonRotation = new JsonArray(rotationXYZ);//⼀个JsonArray对象,也可以是⼀个Value,//所以可以⽤jsonTransform来AddjsonTransform.Add("rotation", jsonRotation);//打印结果Debug.Log(jsonTransform);JsonObject x = new JsonObject();x.Add("x", 10);JsonObject y = new JsonObject();y.Add("y", 20);JsonObject z = new JsonObject();z.Add("z", 30);//实例⼀个jsonValues数组(所有类型都可以转换成jsonValue)JsonValue[] scaleXYZ = new JsonValue[] { x, y, z };//将实例好了的数组,添加到jsonArray对象中,形成⼀个jsonArray对象//作⽤在于给这个整体,添加⼀个中括号[]JsonArray jsonScale = new JsonArray(scaleXYZ);//将这个整体,放⼊到jsonTransform中jsonTransform.Add("scale", jsonScale);//打印结果Debug.Log(jsonTransform);}
}

打印结果:

五、LitJson

常用API方法如下:

  • 把对象转化成JSON格式字符串:JsonMapper.ToJson
  • 把JSON格式字符串转化成对象:JsonMapper.ToObject
  • 把JSON格式字符串转化成指定类的对象:JsonMapper.ToObject

1.生成

我们写一个字段类Person,类里面有string类型的"Name"和int型的"Age"
 

using System.IO;
using UnityEngine;[System.Serializable]
class Person
{public string Name;public int Age;
}
[System.Serializable]
class Data
{public Person[] Person;
}
public class NewBehaviourScript : MonoBehaviour
{void Start(){WriteData();}//写数据public void WriteData(){//新建一个数据类Data m_Data = new Data();//新建一个字段类 进行赋值m_Data.Person = new Person[3];for (int i = 0; i < 3; i++){Person m_Person = new Person();m_Person.Name = "User" + i;m_Person.Age = 20 + i;m_Data.Person[i] = m_Person;}//将数据转成jsonstring js = JsonUtility.ToJson(m_Data);//获取到项目路径string fileUrl = Application.dataPath + "\\jsonInfo.txt";//打开或者新建文档using (StreamWriter sw = new StreamWriter(fileUrl)){//保存数据sw.WriteLine(js);//关闭文档sw.Close();sw.Dispose();}}
}

2.解析

先读取Json文件,使用IO命名空间下的File类的OpenText()函数进行读取
然后使用JsonUtility.FromJson进行解析

using System.IO;
using UnityEngine;[System.Serializable]
class Person
{public string Name;public int Age;
}
[System.Serializable]
class Data
{public Person[] Person;
}
public class NewBehaviourScript : MonoBehaviour
{void Start(){string jsonData = ReadData();Data m_PersonData = JsonUtility.FromJson<Data>(jsonData);foreach (Person item in m_PersonData.Person){Debug.Log(item.Name);Debug.Log(item.Age);}}//读取文件public string ReadData(){//string类型的数据常量string readData;//获取到路径string fileUrl = Application.dataPath + "\\jsonInfo.json";//读取文件using (StreamReader sr = File.OpenText(fileUrl)){//数据保存readData = sr.ReadToEnd();sr.Close();}//返回数据return readData;}
}

这篇关于1.10 Unity中的数据存储 JSON的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593736

相关文章

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二