谈谈Dynamic的DynamicJson

传统操作Json

 

很多.NET开发程序员或多或少都会遇到操作Json字符串的情况,一般来说,我们都是先定义一个和Json格式相匹配的类,然后将json字符串反序列化成对象,这样便于我们编程使用,由于.NET是强类型语言,Json又是多变的,非常灵活的,导致服务器端定义的json序列化类越来越多,操作也及其不便。特别是对多层嵌套的json更是头疼。此次不再过多声明,.NET程序员用过都明白。

 

简易操作Json

 

DynamicJson是专门为.NET程序员开发的Json操作库,其源码非常简单,仅仅只有400行代码,一个对应的class类,目前只支持.NET 4.0以上的.NET Framework。

 

如何在项目中使用DynamicJson

  • 直接通过Nuget安装

1

PM > Install-Package DynamicJson

  • 下载DynamicJson.dll,然后在项目中添加引用,下载地址如下:

1

http://dynamicjson.codeplex.com/

 

读取、获取

// 将Json字符串解析成DynamicJson对象

var json = DynamicJson.Parse(@"{""foo"":""json"", ""bar"":100, ""nest"":{ ""foobar"":true } }");

var r1 = json.foo; // "json" - string类型

var r2 = json.bar; // 100 - double类型

var r3 = json.nest.foobar; // true - bool类型

var r4 = json["nest"]["foobar"]; // 还可以和javascript一样通过索引器获取

判断,新增,更新,删除,替换,还可以输出新的Json字符串  

// 将Json字符串解析成DynamicJson对象

var json = DynamicJson.Parse(@"{""foo"":""json"", ""bar"":100, ""nest"":{ ""foobar"":true } }");


// 判断json字符串中是否包含指定键

var b1_1 = json.IsDefined("foo"); // true

var b2_1 = json.IsDefined("foooo"); // false

// 上面的判断还可以更简单,直接通过json.键()就可以判断

var b1_2 = json.foo(); // true

var b2_2 = json.foooo(); // false;

// 新增操作

json.Arr = new string[] { "NOR", "XOR" }; // 新增一个js数组

json.Obj1 = new { }; // 新增一个js对象

json.Obj2 = new { foo = "abc", bar = 100 }; // 初始化一个匿名对象并添加到json字符串中

// 删除操作

json.Delete("foo");
json.Arr.Delete(0);

// 还可以更简单去删除,直接通过json(键); 即可删除。
json("bar");
json.Arr(1);

// 替换操作
json.Obj1 = 5000;

// 创建一个新的JsonObject
dynamic newjson = new DynamicJson();
newjson.str = "aaa";
newjson.obj = new { foo = "bar" };

// 直接序列化输出json字符串
var jsonstring = newjson.ToString(); // {"str":"aaa","obj":{"foo":"bar"}}

 

遍历

// 直接遍历json数组

var arrayJson = DynamicJson.Parse(@"[1,10,200,300]");
 foreach (int item in arrayJson)
  {
      Console.WriteLine(item); // 1, 10, 200, 300
  }


 // 直接遍历json对象

 var objectJson = DynamicJson.Parse(@"{""foo"":""json"",""bar"":100}");
  foreach (KeyValuePair<string, dynamic> item in objectJson)
  {
   Console.WriteLine(item.Key + ":" + item.Value); // foo:json, bar:100
  }

转换和反序列化

var arrayJson = DynamicJson.Parse(@"[1,10,200,300]");
var objectJson = DynamicJson.Parse(@"{""foo"":""json"",""bar"":100}");

// 将json数组转成C#数组
// 方法一:
var array1 = arrayJson.Deserialize<int[]>();
// 方法二
var array2 = (int[])arrayJson;

// 方法三,这种最简单,直接声明接收即可,推荐使用

int[] array3 = arrayJson;

// 将json字符串映射成C#对象
// 方法一:

var foobar1 = objectJson.Deserialize<FooBar>();

// 方法二:
var foobar2 = (FooBar)objectJson;

// 方法三,这种最简单,直接声明接收即可,推荐使用
FooBar foobar3 = objectJson;

// 还可以通过Linq进行操作
var objectJsonList = DynamicJson.Parse(@"[{""bar"":50},{""bar"":100}]");
var barSum = ((FooBar[])objectJsonList).Select(fb => fb.bar).Sum(); // 150
var dynamicWithLinq = ((dynamic[])objectJsonList).Select(d => d.bar);

序列化成json字符串

public class FooBar
{
    public string foo { get; set; }
    public int bar { get; set; }
}


// 声明一个匿名对象
var obj = new
{
    Name = "Foo",
    Age = 30,
    Address = new
    {
        Country = "Japan",
        City = "Tokyo"
    },
    Like = new[] { "Microsoft", "Xbox" }
};

// 序列化
// {"Name":"Foo","Age":30,"Address":{"Country":"Japan","City":"Tokyo"},"Like":["Microsoft","Xbox"]}
var jsonStringFromObj = DynamicJson.Serialize(obj);

// 还支持直接序列化数组,集合
// [{"foo":"fooooo!","bar":1000},{"foo":"orz","bar":10}]
var foobar = new FooBar[] {
new FooBar { foo = "fooooo!", bar = 1000 },
new FooBar { foo = "orz", bar = 10 }
};

// 序列化
var jsonFoobar = DynamicJson.Serialize(foobar);

生成xml字符串

var obj = DynamicJson.Parse(@"{""tes"":10,""nest"":{""a"":0}");
var xmlStr=obj.xml;

 

其他(冲突问题,编译不通过问题)

var nestJson = DynamicJson.Parse(@"{""tes"":10,""nest"":{""a"":0}");

nestJson.nest(); // 判断是否存在nest属性
nestJson.nest("a"); // 删除nest属性中的a属性

// 处理json中的键和C#的类型冲突导致编译失败,或语法提示错误,只需要在前面加@前缀即可
var json = DynamicJson.Parse(@"{""int"":10,""event"":null}");
var r1 = json.@int; // 10.0
var r2 = json.@event; // null

 

例子:TwitterAPI

static void Main()
{
    var publicTL = new WebClient().DownloadString(@"http://twitter.com/statuses/public_timeline.json");
    var statuses = DynamicJson.Parse(publicTL);
    foreach (var status in statuses)
    {
        Console.WriteLine(status.user.screen_name);
        Console.WriteLine(status.text);
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值