一.Linq to JSON是用来干什么的?

  Linq to JSON是用来操作JSON对象的.可以用于快速查询,修改和创建JSON对象.当JSON对象内容比较复杂,而我们仅仅需要其中的一小部分数据时,可以考虑使用Linq to JSON来读取和修改部分的数据而非反序列化全部.

二.创建JSON数组和对象

在进行Linq to JSON之前,首先要了解一下用于操作Linq to JSON的类.

类名 说明
JObject
 用于操作JSON对象
JArray
 用语操作JSON数组
JValue
 表示数组中的值
JProperty
 表示对象中的属性,以"key/value"形式
JToken
 用于存放Linq to JSON查询后的结果

1.创建JSON对象

            JObject staff = new JObject();staff.Add(new JProperty("Name", "Jack"));staff.Add(new JProperty("Age", 33));staff.Add(new JProperty("Department", "Personnel Department"));staff.Add(new JProperty("Leader", new JObject(new JProperty("Name", "Tom"), new JProperty("Age", 44), new JProperty("Department", "Personnel Department"))));Console.WriteLine(staff.ToString());

结果:

除此之外,还可以通过一下方式来获取JObject.JArray类似。

方法   说明
JObject.Parse(string json)
json含有JSON对象的字符串,返回为JObject对象
JObject.FromObject(object o)

o为要转化的对象,返回一个JObject对象

JObject.Load(JsonReader reader)
reader包含着JSON对象的内容,返回一个JObject对象

2.创建JSON数组

            JArray arr = new JArray();arr.Add(new JValue(1));arr.Add(new JValue(2));arr.Add(new JValue(3));Console.WriteLine(arr.ToString());

结果:

三.使用Linq to JSON

1.查询
首先准备Json字符串,是一个包含员工基本信息的Json

string json = "{\"Name\" : \"Jack\", \"Age\" : 34, \"Colleagues\" : [{\"Name\" : \"Tom\" , \"Age\":44},{\"Name\" : \"Abel\",\"Age\":29}] }";

①获取该员工的姓名

            //将json转换为JObjectJObject jObj = JObject.Parse(json);//通过属性名或者索引来访问,仅仅是自己的属性名,而不是所有的JToken ageToken =  jObj["Age"];Console.WriteLine(ageToken.ToString());

结果:

②获取该员工同事的所有姓名

            //将json转换为JObjectJObject jObj = JObject.Parse(json);var names=from staff in jObj["Colleagues"].Children()select (string)staff["Name"];foreach (var name in names)Console.WriteLine(name);

"Children()"可以返回所有数组中的对象

结果:

2.修改

①现在我们发现获取的json字符串中Jack的年龄应该为35

            //将json转换为JObjectJObject jObj = JObject.Parse(json);jObj["Age"] = 35;Console.WriteLine(jObj.ToString());

结果:

注意不要通过以下方式来修改:

            JObject jObj = JObject.Parse(json);JToken age = jObj["Age"];age = 35;

②现在我们发现Jack的同事Tom的年龄错了,应该为45

            //将json转换为JObjectJObject jObj = JObject.Parse(json);JToken colleagues = jObj["Colleagues"];colleagues[0]["Age"] = 45;jObj["Colleagues"] = colleagues;//修改后,再赋给对象Console.WriteLine(jObj.ToString());

结果:

3.删除
①现在我们想删除Jack的同事

            JObject jObj = JObject.Parse(json);jObj.Remove("Colleagues");//跟的是属性名称Console.WriteLine(jObj.ToString());

结果:

②现在我们发现Abel不是Jack的同事,要求从中删除

            JObject jObj = JObject.Parse(json);jObj["Colleagues"][1].Remove();Console.WriteLine(jObj.ToString());

结果:

4.添加
①我们发现Jack的信息中少了部门信息,要求我们必须添加在Age的后面

            //将json转换为JObjectJObject jObj = JObject.Parse(json);jObj["Age"].Parent.AddAfterSelf(new JProperty("Department", "Personnel Department"));Console.WriteLine(jObj.ToString());

结果:

②现在我们又发现,Jack公司来了一个新同事Linda

            //将json转换为JObjectJObject jObj = JObject.Parse(json);JObject linda = new JObject(new JProperty("Name", "Linda"), new JProperty("Age", "23"));jObj["Colleagues"].Last.AddAfterSelf(linda);Console.WriteLine(jObj.ToString());

结果:

四.简化查询语句

使用函数SelectToken可以简化查询语句,具体:
①利用SelectToken来查询名称

            JObject jObj = JObject.Parse(json);JToken name = jObj.SelectToken("Name");Console.WriteLine(name.ToString());

结果:

②利用SelectToken来查询所有同事的名字

            JObject jObj = JObject.Parse(json);var names = jObj.SelectToken("Colleagues").Select(p => p["Name"]).ToList();foreach (var name in names)Console.WriteLine(name.ToString());

结果:

③查询最后一名同事的年龄

            //将json转换为JObjectJObject jObj = JObject.Parse(json);var age = jObj.SelectToken("Colleagues[1].Age");Console.WriteLine(age.ToString());

结果:

FAQ

1.如果Json中的Key是变化的但是结构不变,如何获取所要的内容?

例如:

 1 {2 "trends":3 {4 "2013-05-31 14:31":5 [6 {"name":"我不是谁的偶像",7 "query":"我不是谁的偶像",8 "amount":"65172",9 "delta":"1596"},
10 {"name":"世界无烟日","query":"世界无烟日","amount":"33548","delta":"1105"},
11 {"name":"最萌身高差","query":"最萌身高差","amount":"32089","delta":"1069"},
12 {"name":"中国合伙人","query":"中国合伙人","amount":"25634","delta":"2"},
13 {"name":"exo回归","query":"exo回归","amount":"23275","delta":"321"},
14 {"name":"新一吻定情","query":"新一吻定情","amount":"21506","delta":"283"},
15 {"name":"进击的巨人","query":"进击的巨人","amount":"20358","delta":"46"},
16 {"name":"谁的青春没缺失","query":"谁的青春没缺失","amount":"17441","delta":"581"},
17 {"name":"我爱幸运七","query":"我爱幸运七","amount":"15051","delta":"255"},
18 {"name":"母爱10平方","query":"母爱10平方","amount":"14027","delta":"453"}
19 ]
20 },
21 "as_of":1369981898
22 }

其中的"2013-05-31 14:31"是变化的key,如何获取其中的"name","query","amount","delta"等信息呢?
通过Linq可以很简单地做到:

 var jObj = JObject.Parse(jsonString);var tends = from c in jObj.First.First.First.First.Children()select JsonConvert.DeserializeObject<Trend>(c.ToString());
public class Trend
{public string Name { get; set; }public string Query { get; set; }public string Amount { get; set; }public string Delta { get; set; }
}

转载于:https://www.cnblogs.com/gygang/p/8954376.html

asp.net JObject 操作相关推荐

  1. 【译】在Asp.Net中操作PDF – iTextSharp -利用块,短语,段落添加文本

    本篇文章是讲述使用iTextSharp这个开源组件的系列文章的第三篇,iTextSharp可以通过Asp.Net创建PDFs,就像HTML和ASP.Net为文本提供了多种容器一样,iTextSharp ...

  2. asp.net word操作

    在ASP.NET里操作Word的第一步就是添加COM引用到你的工程里,通过右键点击"解决方案资源管理器"的"引用",添加引用.选择COM选项卡,添加Micros ...

  3. ASP.NET 如何操作文件

    本文由chenyangasp版权所有,可以转载,复制,粘贴,并请注明出处,但不得修改! 在asp.net操作文件的所有concept都在system.io  namespace中,这个namespac ...

  4. 在ASP.NET中操作文件的例子

    利用SYSTEM.IO 名空间中的STREAMWRITER,STREAMREADER及FILE类,完成文件读.写.删除的操作.  ----------------------------------- ...

  5. asp.net 文件操作

    在ASP.NET中,文件处理的整个过程都是围绕着System.IO 这个名称空间展开的.这个名称空间中具有执行文件读.写所需要的类.Directory用于创建.移动和枚举通过目录和子目录,File用于 ...

  6. ASP.Net 中操作Ajax

    有时候,越深入去了解一个点,越发觉得自己无知,而之前当自己晓得一两个片面的点还洋洋自得,殊不知,这是多么讽刺,JQuery中有很多优势,比如异步提交值,部分刷新,给用户很好的体验感.目前为止,大部分项 ...

  7. asp.net窗体操作总结

    这些代码全部写在和页面分离的代码页中(codebehind),如果要嵌入到*.aspx页面,可能 会出现问题. 1.打开新窗口   这个简单:Response.Write(@"<scr ...

  8. Asp.net 字符串操作基类(安全,替换,分解等)

    /############################################ 版权声明: 文章内容为本站编辑,创作.你可以任意转载.发布.使用但请务必明文标注文章原始出处及本声明 htt ...

  9. ASP.NET文件操作收藏

    System.IO Directory:用于创建.移动和枚举通过目录和子目录 File:用于创建.复制.删除.移动和打开文件 Path:对包含文件或目录路径信息的String实例执行操作 Stream ...

最新文章

  1. html5画布显示不出来,运行后html5画布没出来
  2. 智慧城市 android,基于Android系统的智慧城市服务客户端的设计与实现
  3. 默认析构函数与空析构函数并不完全等价
  4. python win32库与subprocess_依赖管理:Python2.7需要subprocess32
  5. 列表页时间日期标签靠显示html,帝国CMS列表页面list.var分别调用年月日,显示个性时间日期...
  6. yoga11rt系统刷linux,【攻略贴】联想Yoga“一秒”变身安卓平板,Win8 Andriod双系统刷机攻略出炉!...
  7. 很久没写了,今天兴致来了,写一下!
  8. 手机QQ Hybrid 的架构演进
  9. STM32单片机雨滴模块
  10. 超级终端连接华为交换机_小编解决win8系统使用超级终端连接华为交换机的设置步骤...
  11. Redis集群:./redis-trib.rb:24:in `require': no such file to load -- rubygems
  12. HTML5+CSS大作业——清新春暖花开个人博客网站(6页)
  13. Xbox One Dance Central Spotlight 歌曲列表
  14. 淘宝API接口(item_search-按关键字搜索淘宝商品 )
  15. sim卡没坏但苹果手机无服务_iPhone 卡贴机换卡案例,无服务与SIM卡无效解决方案...
  16. 歌曲转调之后和弦如何转换
  17. Python爬虫方式抓取免费http代理IP
  18. 软技能-代码之外的生存指南读后感 学习篇
  19. 长轮询和短轮询的区别
  20. ygomobile卡组下载网站_YGOMobile:用手机也能免费玩游戏王

热门文章

  1. JVM原理系列--元空间(MetaSpace)与永久代(PermGen)的区别
  2. python中random模块验证码_Python之random模块详解
  3. 弗洛伊德(Floyd)算法求解图的最短路径
  4. GitHub 记录一下走过的坑
  5. java 检查bytebuf长度_ByteBuf分析
  6. 根据html除去多余css样式在线,利用css-redundancy-checker去除冗余、无用、废弃的css样式代码...
  7. 07-08NBA总冠军预测
  8. 微信公众号之微信登录失败,redirect_uri域名与后台配置不一致,错误代码10003
  9. 多维度介绍MOS管,了解MOS管,看这个就够了!
  10. win10系统应用打不开