一般来说,正常的 json 长这个模样:

{
'Name': 'Bad Boys',
'ReleaseDate': '1995-4-7T00:00:00',
'Genres': [
'Action',
'Comedy'
]
}

这个时候我们只需要建立对应的类,直接反序列化就行(比如宇宙第一VS的 “编辑” -- “选择性粘贴” -- “将JSON粘贴为类”)

    public class Movie
{
public string Name { get; set; }
public string ReleaseDate { get; set; }
public string[] Genres { get; set; }
} Movie m = JsonConvert.DeserializeObject<Movie>(json);

不过有的时候会有些不负责任的 JSON

有时候它长这样:

{
"mapping": [{
"PHARMACOLOGY": "TU",
"NEUROSCIENCES": "RU"
}]
}

有时候它还长这样:

{
"mapping": [{
"TELECOMMUNICATIONS": "YE"
}]
}

这个时候序列化我们就需要 字典 (Dictionary)

这个时候我们的类要长这样:

    public class Rootobject
{
public List<Dictionary<string, string>> mapping { get; set; }
}

然后照常反序列化:

Rootobject root = JsonConvert.DeserializeObject<Rootobject>(JSON);

循环下输出结果:

                        i++;
foreach (var temp in root.mapping[0])
{
Console.WriteLine(String.Format("Number:{0},Keys:{1},Values:{2}", i, temp.Key, temp.Value));
}

结果如下:

如果更麻烦一点的呢?

比如我在 https://blog.csdn.net/jdsjlzx/article/details/76785239 看到的这个json:

{
"resultcode": "",
"reason": "successed!",
"result": {
"sk": {
"temp": "",
"wind_direction": "东北风",
"wind_strength": "2级",
"humidity": "28%",
"time": "17:38"
},
"today": {
"temperature": "15℃~26℃",
"weather": "多云转晴",
"wind": "东北风微风",
"week": "星期日",
"city": "桂林",
"date_y": "2015年10月11日",
"dressing_index": "舒适",
"dressing_advice": "建议着长袖T恤、衬衫加单裤等服装。年老体弱者宜着针织长袖衬衫、马甲和长裤。",
"uv_index": "弱",
"comfort_index": "",
"wash_index": "较适宜",
"travel_index": "较适宜",
"exercise_index": "较适宜",
"drying_index": ""
},
"future": {
"day_20151011": {
"temperature": "15℃~26℃",
"weather": "多云转晴",
"wind": "东北风微风",
"week": "星期日",
"date": ""
},
"day_20151012": {
"temperature": "16℃~27℃",
"weather": "晴转多云",
"wind": "微风",
"week": "星期一",
"date": ""
},
"day_20151013": {
"temperature": "16℃~26℃",
"weather": "多云转晴",
"wind": "微风",
"week": "星期二",
"date": ""
},
"day_20151014": {
"temperature": "17℃~27℃",
"weather": "晴",
"wind": "北风微风",
"week": "星期三",
"date": ""
},
"day_20151015": {
"temperature": "17℃~28℃",
"weather": "晴",
"wind": "北风微风",
"week": "星期四",
"date": ""
},
"day_20151016": {
"temperature": "17℃~30℃",
"weather": "晴",
"wind": "北风微风",
"week": "星期五",
"date": ""
},
"day_20151017": {
"temperature": "17℃~30℃",
"weather": "晴",
"wind": "北风微风",
"week": "星期六",
"date": ""
}
}
},
"error_code": 0
}

继续使用 Dictionary 定义类:

    public class WeatherRootobject
{
public string resultcode { get; set; }
public string reason { get; set; }
public Result result { get; set; }
public int error_code { get; set; }
} public class Result
{
public Sk sk { get; set; }
public Today today { get; set; }
public Dictionary<string, Weather> future { get; set; }
} public class Sk
{
public string temp { get; set; }
public string wind_direction { get; set; }
public string wind_strength { get; set; }
public string humidity { get; set; }
public string time { get; set; }
} public class Today
{
public string temperature { get; set; }
public string weather { get; set; }
public string wind { get; set; }
public string week { get; set; }
public string city { get; set; }
public string date_y { get; set; }
public string dressing_index { get; set; }
public string dressing_advice { get; set; }
public string uv_index { get; set; }
public string comfort_index { get; set; }
public string wash_index { get; set; }
public string travel_index { get; set; }
public string exercise_index { get; set; }
public string drying_index { get; set; }
} public class Weather
{
public string temperature { get; set; }
public string weather { get; set; }
public string wind { get; set; }
public string week { get; set; }
public string date { get; set; }
}

然后反序列化输出:

            WeatherRootobject weathers = JsonConvert.DeserializeObject<WeatherRootobject>(json);
foreach (var temp in weathers.result.future)
{
Console.WriteLine(String.Format("Day:{0},Week:{1},Temperature:{2}", temp.Key, temp.Value.week, temp.Value.temperature));
}

结果如下:

含有动态未知字段的 JSON 反序列化的更多相关文章

  1. java对象中含有Integer类型字段转json字符串问题

    问题:对于含有Integer类型字段的java对象,在通过下面这种方式转为json字符串时,Integer类型的字段如果为空的情况下,会默认转化为0,但是我想让它为空的时候直接转化为null,不要默认 ...

  2. C#动态实体集的反序列化(动态JSON反序列化)

    一.使用场景 我们在将 JSON 反序列化实体集的时候,如果字段是固定的,那么我们序列化非常简单,对应字段写的实体集就可以了.比如下面这种: { "data":[ { " ...

  3. C# Json反序列化 C# 实现表单的自动化测试<通过程序控制一个网页> 验证码处理类:UnCodebase.cs + BauDuAi 读取验证码的值(并非好的解决方案) 大话设计模式:原型模式 C# 深浅复制 MemberwiseClone

    C# Json反序列化   Json反序列化有两种方式[本人],一种是生成实体的,方便处理大量数据,复杂度稍高,一种是用匿名类写,方便读取数据,较为简单. 使用了Newtonsoft.Json,可以自 ...

  4. C#在Json反序列化中处理键的特殊字符

    假设有如下Json 数据: 1.{ 2."id" : 1, 3."@value" : "this a @", 4."$p" ...

  5. Sql动态添加字段的正确姿势

    如何给指定表动态添加字段? 一.创建一张表[Tbl_AutoFileds] (tableName表名,fieldName字段名,dataType数据类型,length长度  isnull 是否允许为n ...

  6. odoo 动态创建字段的方法

    动态创建字段并非一个常见的的需求,但某些情况下,我们确实又需要动态地创建字段. Odoo 中创建字段的方法有两种,一种是通过python文件class中进行定义,另一种是在界面上手工创建,odoo通过 ...

  7. Dynamic CRM 2013学习笔记(二十八)用JS动态设置字段的change事件、必填、禁用以及可见

    我们知道通过界面设置字段的change事件,是否是必填,是否可见非常容易.但有时我们需要动态地根据某些条件来设置,这时有需要通过js来动态地控制了. 下面分别介绍如何用js来动态设置.   一.动态设 ...

  8. C# Json反序列化处理

    最近换工作了 从客户端转到Web端 第一个任务就是去别人的页面上抓取数据 用到的是JSON 因为他们网站json的格式有点怪 所以 就在JSON反序列化上面 花了一点时间 首先用到的工具是http:/ ...

  9. 利用DreamweaverCS5制作一个含有动态标题的教程

    DreamweaverCS5怎么制作一个含有动态标题?做一个网页就先要做一个标题,一个好标题会让网页让人印象深刻,有动态的标题会让网页更生动,下面我就介绍一下怎么制作一个含有动态的标题   做一个网页 ...

随机推荐

  1. 01-C#笔记-hello_world

    /* * 主文件是 xxx.cs * 基本的 hello world 程序如下: */ using System; using System.Collections.Generic; using Sy ...

  2. 完美解决该死的ie6下select总是置于最上层bug

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  3. [教程]Ubuntu16.04安装QQ,Tim,微信,百度网盘等

    [教程]Ubuntu16.04安装QQ,Tim,微信,百度网盘等 本文参考这篇blog step 1 先安装 deep-win环境. 戳这里下载压缩包 解压后在文件夹里打开终端,输入 sudo sh ...

  4. date命令的FORMAT中输入空格的几种方法

    1.date +%Y-%m-%d\ (一个空格)%H:%M:%S 此命令中用了转义字符 \ ,将空格转义出来 2.date +%Y-%m-%d'  '%H:%M:%S 此命令中的单引号内可以是一个或多 ...

  5. luogu_2480: 古代猪文

    洛谷:2480古代猪文 题意描述: 给定两个整数\(N,G\),求$G^{\sum_{k|n}C_n^k} mod 999911659 $. 数据范围: \(1\leq N\leq 10^9,1\le ...

  6. 洛谷P3084 [USACO13OPEN]照片

    题目 \(DP\) 设状态\(dp[i]\)为\(i\)位置放了斑点牛,前\(i\)个位置能得到的最多的牛. 有方程\(dp[i]=max(dp[j]+1,dp[i])\),而我们并不知道什么\(j\ ...

  7. nmap 速查手册

     0x00:说明 只是一个快速查询手册,理论的东西都没有补充,欢迎大家积极在评论区补充自己常用的参数,O(∩_∩)O 0x01:nmap功能介绍 1.主机存活检测2.端口探测3.服务识别4.操作系统识 ...

  8. SpringData JPA实现增删改查

    application.properties配置 一.创建实体类并自动生成数据库表 二.dao层继承JpaRepository 三.controller中增加操作 结果: 删除操作: 修改操作:

  9. Affy包 estrogen包

    下载安装 if (!requireNamespace("BiocManager", quietly = TRUE)) install.packages("BiocMana ...

  10. curl用法详解

    前言 昨天现场的浏览器崩溃了,楼主苦逼,就临时用了curl测试了下图片请求接口.今天总结下. 一.what? curl is a tool to transfer data from or to a ...