c#: Newtonsoft.Json 高级用法一(不创建类,动态解析和构造json、JObject/JArray)

本文主要是介绍c#: Newtonsoft.Json 高级用法一(不创建类,动态解析和构造json、JObject/JArray),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境:

  • .net core3.1
  • vs2019
  • Newtonsoft.Json 12.0.3

关于newtonsoft.json的使用常见问题参考:
《c#:序列化json常见问题及处理方法》
《c#:关于NewtonsoftJson序列化和Grpc序列化的冲突问题》

问题:如何在不新建类的情况下动态解析json字符串?

如下面:

{"Color": {"Red": 0.8,"Blue": 1.2},"Category": {"Better": [ 99, 98, 100, 96 ],"Normal": [ 80, 75, 84 ]}
}

问: 为什么不能使用指定的类进行反序列化?
答: json中的格式不能完全确定,可能是为将来保留,或者是供别人使用,而自己只负责读写其中的一块,如:“$.Color”

下面的代码就演示如何动态解析这个json字符串:

static void TestReadJson()
{var json = @"
{""Color"": {""Red"": 0.8,""Blue"": 1.2},""Category"": {""Better"": [ 99, 98, 100, 96 ],""Normal"": [ 80, 75, 84 ]}
}";JObject obj = Newtonsoft.Json.JsonConvert.DeserializeObject<JObject>(json);//color_red=0.8var color_red = obj["Color"]["Red"].Value<decimal>();//color_blue=1.2var color_blue = obj["Color"]["Blue"].Value<double>();//other ==null truevar other = obj["Color:NotExsit"];Console.WriteLine($"other==null => {other == null}");//d = 99var d = obj["Category"]["Better"][0].Value<int>();//遍历所有属性var propNameList = new List<string>();var propValueList = new List<double>();var props = (obj["Color"] as JObject).Properties();foreach (var prop in props){propNameList.Add(prop.Name);propValueList.Add(prop.Value.Value<double>());}//propNameList=Red,Blue//propValueList=0.8,1.2//遍历数组所有元素var values = new List<int>();var arr = obj["Category"]["Better"] as JArray;foreach (var item in arr){values.Add(item.Value<int>());}//values=99, 98, 100, 96
}

问题: 如何在不新建类的情况下动态组装json?

上面只说了动态解析,那么还有动态组装json的情况,如下面的json:

{"Color": {"Red": 0.8,"Blue": 1.2},"Category": {"Better": [ 99, 98, 100, 96 ],"Normal": [ 80, 75, 84 ],"Bad": [undefined,null]}
}

看下面的代码:

static void TestCreateJson()
{/* 手动组装json{"Color": {"Red": 0.8,"Blue": 1.2},"Category": {"Better": [ 99, 98, 100, 96 ],"Normal": [ 80, 75, 84 ],"Bad": [undefined,null]}}*///写入JObject//创建json字符串根节点var obj = new JObject(); //{}//Color节点obj["Color"] = new JObject();// { "Color" : {} }obj["Color"]["Red"] = 0.8;// { "Color" : { "Red" : 0.8  } }obj["Color"]["Blue"] = 1.2;// { "Color" : { "Red" : 0.8 , "Blue" : 1.2 } }//Category节点obj["Category"] = new JObject();// { "Color" : { "Red" : 0.8 , "Blue" : 1.2 }, "Category": {} }//Category->Better数组obj["Category"]["Better"] = new JArray();(obj["Category"]["Better"] as JArray).Add(99);(obj["Category"]["Better"] as JArray).Add(98);(obj["Category"]["Better"] as JArray).Add(100);(obj["Category"]["Better"] as JArray).Add(96); //{ "Color" : { "Red" : 0.8 , "Blue" : 1.2 }, "Category": { “Better”: [99, 98, 100, 96] } }//Category->Normal数组obj["Category"]["Normal"] = new JArray();(obj["Category"]["Normal"] as JArray).Add(80);(obj["Category"]["Normal"] as JArray).Add(75);(obj["Category"]["Normal"] as JArray).Add(84);//{ "Color" : { "Red" : 0.8 , "Blue" : 1.2 }, "Category": { “Better”: [99, 98, 100, 96], “Normal”: [80, 75, 84] } }//Category->Bad数组obj["Category"]["Bad"] = new JArray();(obj["Category"]["Bad"] as JArray).Add(JValue.CreateUndefined());(obj["Category"]["Bad"] as JArray).Add(JValue.CreateNull());//{ "Color" : { "Red" : 0.8 , "Blue" : 1.2 }, "Category": { “Better”: [99, 98, 100, 96], “Normal”: [80, 75, 84], "Bad": [ undefined, null ] } }//输出jsonvar jsonStr = obj.ToString();
}

问题: 如何在不新建类的情况下改写json?

既然上面有了动态解析和组装,那么就有改写部分json的需求,看如下代码:

static void TestUpdateJson()
{var json = @"
{""Color"": {""Red"": 0.8,""Blue"": 1.2},""Category"": {""Better"": [ 99, 98, 100, 96 ],""Normal"": [ 80, 75, 84 ],""Bad"": [undefined,null]}
}";var obj = Newtonsoft.Json.JsonConvert.DeserializeObject<JObject>(json);obj["Color"] = "Red,Blue";obj["Category"]["Better"][0] = 100;obj["Category"]["Normal"][0] = new JObject();json = obj.ToString();/*{"Color": "Red,Blue","Category": {"Better": [100,98,100,96],"Normal": [{},75,84],"Bad": [null,null]}}*/
}

问题: 如何动态删除json里的内容?

直接看代码:

static void TestDeleteJson()
{var json = @"
{""Color"": {""Red"": 0.8,""Blue"": 1.2},""Category"": {""Better"": [ 99, 98, 100, 96 ],""Normal"": [ 80, 75, 84 ],""Bad"": [undefined,null]}
}";//移除属性和数组元素var obj = Newtonsoft.Json.JsonConvert.DeserializeObject<JObject>(json);(obj["Color"] as JObject).Remove("Red");(obj["Category"] as JObject).Remove("Better");obj["Category"]["Normal"][0].Remove();json = obj.ToString();/*{"Color": {"Blue": 1.2},"Category": {"Normal": [80,75,84],"Bad": [null,null]}}*/
}

问题:用考虑json文件中的注释吗?

用!!!
因为,我们现在是将json读取到JArray/JObject,Newtonsoft.Json 会将注释一并读取到结构,所以我们要手动排除注释的干扰,具体可参考:
《Newtonsoft.Json 反序列化注意点》

这篇关于c#: Newtonsoft.Json 高级用法一(不创建类,动态解析和构造json、JObject/JArray)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

spring中的@MapperScan注解属性解析

《spring中的@MapperScan注解属性解析》@MapperScan是Spring集成MyBatis时自动扫描Mapper接口的注解,简化配置并支持多数据源,通过属性控制扫描路径和过滤条件,利... 目录一、核心功能与作用二、注解属性解析三、底层实现原理四、使用场景与最佳实践五、注意事项与常见问题六