json的使用(JObect,JsonData,JArray)
- JObect与JsonData的区别
JsonData是JObect的简化版本
2.转换过程容易出的bug
JsonData:当里面存在null就无法转换
解决方案: JsonData teamjd = JsonMapper.ToObject(FindDoctor("0",orgID).Replace(":null", ":\"\"")); //将JsonData中的null替换为“”
JObect :转化为JObect失败
解决方案:失败原因是转化对象是数组要转换为JArray JArray jArray=JArray.Parse(str);
JObect :jArray[0]不能直接转换为JObect
解决方案:JObject jObject = jArray[0] as JObject;
JObect:当JObect对象内部存在数组无法通过Count取值
解决方案:
foreach (JToken field in jObject["data"]["doctors"])
{
if ((field["name"].ToString()).Equals(docName.Trim()))
{
doctorid = field["id"].ToString();
break;
}
}
3.判断json值为空
JObect: jb.ToString().Equals("") 若不为空就会返回jsonObect
JsonData : jd.Count==0
4.json对象的转换
JsonData :当内部存在数组
json["userFamilyHistory"] = new JsonData();
json["userFamilyHistory"].SetJsonType(JsonType.Array);
json["userFamilyHistory"].Add(userFamilyHistory);
JObect:当内部存在数组
List<JObject> listHistory = new List<JObject>();
Object other = new JObject();
...............
listHistory.Add(other);
jObject.Add(new JProperty("history", listHistory));
注意:JsonConvert.SerializeObject() 可以将类,datatable直接转化为json字符串
5.对json应用的小技巧
//根据json创建表 private void createTable(JArray jArray,string tabName)
{
JObject jObject = jArray[0] as JObject;
//配置签约表
DataTable signTb = new DataTable(tabName);
foreach(var item in jObject)
signTb.Columns.Add(item.Key); foreach (JObject obj in jArray)
{
DataRow newrow = signTb.NewRow();
foreach (var item in obj)
{
newrow[ item.Key ] = item.Value;
}
signTb.Rows.Add(newrow);
}
CommonRse.ds[tabName] = signTb.Copy();
}
json的使用(JObect,JsonData,JArray)的更多相关文章
- JObject 用法 、JProperty 用法、JArray 用法 Linq 转 Json
1.使用LINQ to JSON前,需要引用Newtonsoft.Json的dll和using Newtonsoft.Json.Linq的命名空间.LINQ to JSON主要使用到JObject, ...
- JSON转化为JAVABEAN集合
String str = "[{'id':'392','type':'jpg'},{'id':'393','type':'jpg'},{'id':'377','type':'jpg'}]&q ...
- ASP.NET提取多层嵌套json数据的方法
本文实例讲述了ASP.NET利用第三方类库Newtonsoft.Json提取多层嵌套json数据的方法,具体例子如下. 假设需要提取的json字符串如下: {"name":&quo ...
- .net(c#)提取多层嵌套的JSON
Newtonsoft.Json.Net20.dll 下载请访问http://files.cnblogs.com/hualei/Newtonsoft.Json.Net20.rar 在.net 2.0中提 ...
- c#多层嵌套Json
Newtonsoft.Json.Net20.dll 下载请访问http://files.cnblogs.com/hualei/Newtonsoft.Json.Net20.rar 在.net 2.0中提 ...
- C#解析json的两种方式
C#中Json转换主要使用的几种方法! 这篇主要介绍2.4.第三种方法使用的比较局限,所以我没有深入学习. 第二种方法 我使用比较多的方式,这个方法是.NET内置的,使用起来比较方便 A.利用seri ...
- 提取多层嵌套Json数据
在.net 2.0中提取这样的json {"name":"lily","age":23,"addr":{"ci ...
- 详解ASP.NET提取多层嵌套json数据的方法
本篇文章主要介绍了ASP.NET提取多层嵌套json数据的方法,利用第三方类库Newtonsoft.Json提取多层嵌套json数据的方法,有兴趣的可以了解一下. 本文实例讲述了ASP.NET利用第三 ...
- js Form表单转json格式,及后台接收(多种方法)
转载:https://blog.csdn.net/qq_40138785/article/details/81533015 一.serialize()方法格式:var data = $("# ...
随机推荐
- WPF相关资料集锦
微软官方资料 .NET Framework源代码 https://referencesource.microsoft.com/ 微软官方文档 https://docs.microsoft.com/en ...
- django系列3.1--url路由配置, 正则, 分发include, 分组命名匹配
一.url配置 在django项目中urls.py文件中就是为这个url调用的view(视图)函数之间的映射表,来配置访问的一个url执行什么代码 默认的基本格式: from django.conf. ...
- iOS出现 _OBJC_CLASS_$_ZSHomeServiceDataElementGroupLargeImage", referenced from:以及linker command failed with exit code 1 (use -v to see invocation)的错误分析
先说第一个问题 出现这样的错误我总结的原因有两个,我碰到过的: 1.文件重命名,在你创建文件的时候重名了 2.如果你是在一个类中又创建了一个或者多个类,那么你可能没有实现你写的类,也就是你只是@int ...
- linux下查找命令总结
查找命令总结,which,whereis,find,locate,type http://blog.csdn.net/jessica1201/article/details/8139249 1.f ...
- 我编写 33 个 VSCode 扩展的原因以及管理扩展的经验
简评:使用工具的同时自己创造一些工具或扩展,是一件很棒的事情. 以下"我"指原作者 Fabio 大家好,我叫 Fabio,是一位自学成才的开发人员,热衷于开源和授权.我也喜欢自己制 ...
- clang命令理解程序
Xcode 创建一个mac OS command Line Tool程序 步骤打开终端 cd + 工程路径(绝对路径)(注:拖拽main.m文件到终端) input —preprocessor— ...
- 如何将Ajax请求从异步改为同步
Ajax请求默认的都是异步的 如果想同步 async设置为false就可以(默认是true) var html = $.ajax({ url: "some.PHP", as ...
- week 4 Vocabulary in paper
1.Using action verbs 1.1 deffenence between action verbs and fuzzy verbs Action verbs(strong verbs) ...
- CentOS 7 安装程序介绍
(一).引导菜单 使用 UEFI 引导 Install CentOS Linux 7 选择此选项开始在你的计算机系统中使用图形安装程序安装 CentOS 7 Test this media & ...
- ArcGis10.2破解教程
ArcGis10.2下载地址: https://pan.baidu.com/s/15s5ki_8gf0_732br6h43Hw 破解步骤: 1.完成License Manager的安装. 2.将破解文 ...