newtonsoft.json动态读取json以及动态生成

2024-06-20 03:28

本文主要是介绍newtonsoft.json动态读取json以及动态生成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题

同一个接口返回不同类型的json,json结构相差比较大转换为C#对象不太合适,想着是否可以动态解析。

newtonsoft类

在这里插入图片描述
JTokenType类型

namespace Newtonsoft.Json.Linq
{/// <summary>/// Specifies the type of token./// </summary>public enum JTokenType{/// <summary>/// 未知类型/// </summary>None = 0,/// <summary>/// JSON对象/// </summary>Object = 1,/// <summary>/// JSON数组/// </summary>Array = 2,/// <summary>/// JSON 构造函数/// </summary>Constructor = 3,/// <summary>/// JSON对象的属性/// </summary>Property = 4,/// <summary>/// 备注/// </summary>Comment = 5,/// <summary>/// 整数值/// </summary>Integer = 6,/// <summary>/// 浮点数/// </summary>Float = 7,/// <summary>/// 字符串/// </summary>String = 8,/// <summary>/// 布尔值/// </summary>Boolean = 9,/// <summary>/// null值/// </summary>Null = 10,/// <summary>/// undefined值/// </summary>Undefined = 11,/// <summary>/// 时间类型/// </summary>Date = 12,/// <summary>/// 原始的json值/// </summary>Raw = 13,/// <summary>/// 字节值的集合/// </summary>Bytes = 14,/// <summary>/// GUID值/// </summary>Guid = 15,/// <summary>/// Uri值/// </summary>Uri = 16,/// <summary>/// 时间戳值/// </summary>TimeSpan = 17}
}

读取

JToken

// 以下两种写法都可以被转换为 JToken 类型
string jtokenstring1 = "\"Hello World\"";
string jtokenstring2 = "{\"name\":\"John\",\"age\":30}";
string jtokenstring3 = "10";
JToken jtoken1 = JToken.Parse(jtokenstring1);
Console.WriteLine(jtoken1.Type);
Console.WriteLine(jtoken1.HasValues);
JToken jtoken2 = (JToken)JsonConvert.DeserializeObject(jtokenstring2);
Console.WriteLine(jtoken2.Type);
Console.WriteLine(jtoken2.HasValues);
JToken jtoken3 = JToken.Parse(jtokenstring3);
Console.WriteLine(jtoken3.Type);
Console.WriteLine(jtoken3.HasValues);

在这里插入图片描述

JObject

// 只能序列化标准的 json 字符串
string jobjstring2 = "{\"name\":\"John\",\"age\":30}";
JObject jobj1 = JObject.Parse(jobjstring2);
JObject jobj2 = (JObject)JsonConvert.DeserializeObject(jobjstring2);
Console.WriteLine(jobj1.Type);
Console.WriteLine(jobj1.HasValues);
Console.WriteLine(jobj2.Type);
Console.WriteLine(jobj2.HasValues);

在这里插入图片描述

JArray

// 以下两种写法都可解析
// 主要标识就是字符串两段是中括号
string jarraystring1 = "[\"value1\",\"value2\"]";
string jarraystring2 = "[{\"name\":\"John\",\"age\":30},{\"name\":\"Bob\",\"age\":20}]";
JArray jarray1 = JArray.Parse(jarraystring2);
JArray jarray2 = (JArray)JsonConvert.DeserializeObject(jarraystring2);
Console.WriteLine(jarray1.Type);
Console.WriteLine(jarray1.HasValues);
Console.WriteLine(jarray2.Type);
Console.WriteLine(jarray2.HasValues);

在这里插入图片描述

JProperty

//在JObject中是一个name/JToken键值对
string jobjstring2 = "{\"name\":\"John\",\"age\":30}";
JObject jobj1 = JObject.Parse(jobjstring2);
if (jobj1.HasValues)
{foreach (var property in jobj1.Values<JProperty>()){Console.WriteLine(property.Name);Console.WriteLine(property.Type);Console.WriteLine(property.Value);}
}

在这里插入图片描述

JValue

JObject jsonObject = JObject.Parse("{\"a\":10,\"b\":\"Hello World\",\"c\":10}"); 
// 获取值信息
JValue jvaluea = (JValue)jsonObject["a"];
JValue jvalueb = (JValue)jsonObject["b"];
JValue jvaluec = (JValue)jsonObject["c"]; 
// JValue 两个实例比较
Console.WriteLine("jvaluea.Equals(jvalueb): " + jvaluea.Equals(jvalueb)); // false
Console.WriteLine("jvaluea.Equals(jvaluec): " + jvaluea.Equals(jvaluec)); // true
Console.WriteLine("jvaluea==jvaluec: " + (jvaluea == jvaluec)); // false
Console.WriteLine("jvalueb: " + jvalueb); // Hello World
int intValue = jvaluea.Value<int>(); // 将值转换为整数类型
Console.WriteLine("Integer value: " + intValue);

在这里插入图片描述
只知道是个json字符串如何解析全部的数据

using Newtonsoft.Json;
using Newtonsoft.Json.Linq;namespace JsonStu01;class Program
{static void Main(string[] args){ExampleData data = new ExampleData  {  StringValue = "Hello, World!",  IntValue = 123,  DoubleValue = 456.789,  BooleanValue = true,  DateTimeValue = DateTime.Now,  ArrayValue = new object[] { "item1", 2, 3.14, false, null },  NestedObject = new ExampleNestedData { NestedStringValue = "Nested Value" },  NullableIntValue = 100 // 或者你可以设置为 null 来表示它是可空的  };  string jsonString = JsonConvert.SerializeObject(data, Formatting.Indented);Console.WriteLine(jsonString);var jToken = JToken.Parse(jsonString);Console.WriteLine("========================================");JTokenParsePrint(jToken);Console.WriteLine("========================================");JTokenParsePrint2(jToken);}static void JTokenParsePrint(JToken jToken){if (jToken.HasValues){foreach (var value in jToken.Values()){if (value.HasValues){JTokenParsePrint(value);}else{var res = value as JValue;if (res != null){Console.WriteLine(res);}else{Console.WriteLine("强制转化失败");Console.WriteLine(value.Type);}}}}else{var value = jToken as JValue;Console.WriteLine(value);}}static void JTokenParsePrint2(JToken jToken){if (jToken is JObject jObject)  {  foreach (JProperty property in jObject.Properties())  {  if (property.Value.Type == JTokenType.Object || property.Value.Type == JTokenType.Array)  {  //Console.WriteLine("--- Nested Value ---");  Console.WriteLine($"Property Name: {property.Name}");JTokenParsePrint2(property.Value); // 递归调用  //Console.WriteLine("--- End Nested Value ---");  }else{Console.WriteLine($"Property Name: {property.Name}, Value: {property.Value}");  }}  }  else if (jToken is JArray jArray)  {  foreach (JToken item in jArray)  { if (item.Type == JTokenType.Object || item.Type == JTokenType.Array)  {  //Console.WriteLine("--- Nested Value ---");  JTokenParsePrint2(item); // 递归调用  //Console.WriteLine("--- End Nested Value ---");  }else{Console.WriteLine("Array Item: " + item);  }}  }  else  {  Console.WriteLine("Token Value: " + jToken);  }  }
}public class ExampleNestedData  
{  public string NestedStringValue { get; set; }  
}  public class ExampleData  
{  public string StringValue { get; set; }  public int IntValue { get; set; }  public double DoubleValue { get; set; }  public bool BooleanValue { get; set; }  public DateTime DateTimeValue { get; set; }  public object[] ArrayValue { get; set; }  public ExampleNestedData NestedObject { get; set; }  public Nullable<int> NullableIntValue { get; set; }  
}  

生成json

JToken

JTokenWriter writer = new JTokenWriter();
writer.WriteStartObject();
writer.WritePropertyName("Title");
writer.WriteValue("aaaaaaa???");writer.WritePropertyName("Detail");   writer.WriteStartArray();
writer.WriteValue("Yes");
writer.WriteValue("No");
writer.WriteValue("Unknown");
writer.WriteEndArray();writer.WriteEndObject();JObject o = (JObject)writer.Token;
Console.WriteLine(o.ToString());

在这里插入图片描述

JObject

JObject o = new JObject 
{{"CPU","Intel"},{"Memory",2048},{"Drives",new JArray{"DVD","U盘"}}
};Console.WriteLine(o.ToString());

在这里插入图片描述

JArray

var array = new JArray();
array.Add(new JObject()
{{ "pkgType","type"},{ "pkgPart","pkgPart"},{ "pkgLotId","pkgLotId"},{ "dateCode","dateCode"},{ "dateTime",System.DateTime.Now.ToString()}
});
//不能添加JProperty
Console.WriteLine(array.ToString());

在这里插入图片描述

JProperty

// 创建一个 JProperty 的对象,然后转成字符串值
string propertyname = "name";
string propertyvalue = "John";
JProperty jproperty = new JProperty(propertyname, propertyvalue);
var jp = jproperty.ToString(); // 结果:"name": "John"
Console.WriteLine(jp);
// 下面将 jproperty 对象加入 JObject
JObject jobject = new JObject(); // 将 JProperty 添加到 JObject 中
jobject.Add(jproperty);
string jsonstring = jobject.ToString(); // 将 JObject 转换为字符串
Console.WriteLine(jsonstring);
// 输出:{\r\n  \"name\": \"John\"\r\n}
// 但是通过这个输出的格式进行序列化时,就会提示异常,如下:
string jpropertystring1 = "\"name\": \"John\"";
// Newtonsoft.Json.JsonReaderException:Additional text encountered after finished reading JSON content
var jProperty1 = JProperty.Parse(jpropertystring1); 
var jProperty2 = (JProperty)JsonConvert.DeserializeObject(jpropertystring1);

在这里插入图片描述

JValue

Console.WriteLine(new JValue("aaa").ToString());
Console.WriteLine(new JValue(true).ToString());
Console.WriteLine(new JValue(new Uri("https://hao.360.com/")).ToString());
JObject obj = new JObject();
obj.Add("aaa",new JValue("aaa"));
var arr = new JArray();
arr.Add(new JValue(100));
arr.Add(new JValue(10.0));
arr.Add(new JValue(true));
obj.Add("array",arr);
Console.WriteLine(obj.ToString());

在这里插入图片描述

JSON合并

//JSON合并
var o1Str = @"{'FirstName': 'John','LastName': 'Smith','Enabled': false,'Roles': [ 'User' ]}";
var o2Str = @"{'Enabled': true,'Roles': [  'Admin' ]}";
JObject o1 = JObject.Parse(o1Str);
JObject o2 = JObject.Parse(o2Str);o1.Merge(o2, new JsonMergeSettings
{// union arrays together to avoid duplicatesMergeArrayHandling = MergeArrayHandling.Union
});Console.WriteLine(o1.ToString());

在这里插入图片描述

参考

https://www.cnblogs.com/fanfan-90/p/12659937.html
https://www.cnblogs.com/hnzhengfy/p/JObjectJArray.html

这篇关于newtonsoft.json动态读取json以及动态生成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot如何通过http动态操作xxl-job任务

《springboot如何通过http动态操作xxl-job任务》:本文主要介绍springboot如何通过http动态操作xxl-job任务的问题,具有很好的参考价值,希望对大家有所帮助,如有错... 目录springboot通过http动态操作xxl-job任务一、maven依赖二、配置文件三、xxl-

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python中文件读取操作漏洞深度解析与防护指南

《Python中文件读取操作漏洞深度解析与防护指南》在Web应用开发中,文件操作是最基础也最危险的功能之一,这篇文章将全面剖析Python环境中常见的文件读取漏洞类型,成因及防护方案,感兴趣的小伙伴可... 目录引言一、静态资源处理中的路径穿越漏洞1.1 典型漏洞场景1.2 os.path.join()的陷