一、C#处理简单json数据

json数据:{"result":"0","res_info":"ok","queryorder_info":"info"}

以jsonmy1.txt文件的形式保存在d盘json文件夹下。

构造对象:代码如下:

public struct ToJsonMy

{

public string result { get; set; } //属性的名字,必须与json格式字符串中的"key"值一样。

public string res_info { get; set; }

public string queryorder_info { get; set; }

}

转换过程:

代码如下:

public static void JsonMy()

{

string json = Jsonstr("D:\\json\\jsonmy1.txt");//Jsonstr函数读取json数据的文本txt

JavaScriptSerializer js = new JavaScriptSerializer(); //实例化一个能够序列化数据的类

ToJsonMy list = js.Deserialize<ToJsonMy>(json); //将json数据转化为对象类型并赋值给list

string result = list.result;

string res_info = list.res_info;

string queryorder_info = list.res_info;

}

二、C#处理包含对象的json数据

json数据:jsonmy2.txt

代码如下:

{"result":"0",

"res_info":"ok",

"queryorder_info":{"order_num":"5","orderdetail":"ok"}

}

构造对象:代码如下:

public struct ToJsonMy2

{

public string result { get; set; }

public string res_info { get; set; }

public queryorder_info queryorder_info;

}

public struct queryorder_info

{

public string order_num { get; set; }

public string orderdetail { get; set; }

};

转换过程:代码如下:

public static void JsonMy2()

{

string json = Jsonstr("D:\\json\\jsonmy2.txt");

JavaScriptSerializer js = new JavaScriptSerializer(); //实例化一个能够序列化数据的类

ToJsonMy2 list = js.Deserialize<ToJsonMy2>(json); //将json数据转化为对象类型并赋值给list

string result = list.result;

string res_info = list.res_info;

string order_num = list.queryorder_info.order_num;

string orderdetail = list.queryorder_info.orderdetail;

}

三、C#处理包含对象、数组的json数据

json数据:jsonmy4.txt

代码如下:

{
"result": "0",
"res_info": "ok",
"queryorder_info": {
"order_num": "5",
"orderdetail": [
{
"CFTUin": "769839263",
"CancelDeadline": "2013-09-12 23:00:00",
"CheckInDate": "2013-09-12 00:00:00",
"CheckOutDate": "2013-09-13 00:00:00",
"CityID": "0101",
"CurrencyCode": "RMB",
"HotelID": "00301105",
"HotelName": "速8酒店(北京天坛南门店)",
"ListID": "1000000005201308280002999652",
"PayAmt": "228",
"PayType": "0",
"RommsCnt": "1",
"SPTransID": "65202157",
"State": "4"
},
{
"CFTUin": "248486133",
"CancelDeadline": "2013-10-13 23:00:00",
"CheckInDate": "2013-10-13 00:00:00",
"CheckOutDate": "2013-10-1800:00:00",
"CityID": "0201",
"CurrencyCode": "RMB",
"HotelID": "10201314",
"HotelName": "凯顿",
"ListID": "1000000005201308280002999413",
"PayAmt": "1140",
"PayType": "0",
"RommsCnt": "1",
"SPTransID": "65197226",
"State": "4"
}
]
}
}

构造对象:

代码如下:

public struct ToJsonMy3

{

public string result { get; set; }

public string res_info { get; set; }

public queryorder_info queryorder_info;

}

public struct queryorder_info

{

public string order_num { get; set; }

public List<orderdetail> orderdetail;//数组处理

};

public struct orderdetail

{

public string CFTUin { get; set; }

public string CancelDeadline { get; set; }

public string CheckInDate { get; set; }

public string CheckOutDate { get; set; }

public string CityID { get; set; }

public string CurrencyCode { get; set; }

public string HotelID { get; set; }

public string HotelName { get; set; }

public string ListID { get; set; }

public string PayAmt { get; set; }

public string PayType { get; set; }

public string RommsCnt { get; set; }

public string SPTransID { get; set; }

public string State { get; set; }

};

转换过程:

代码如下:

public static void JsonMy4()

{

string json = Jsonstr("D:\\json\\jsonmy4.txt");

JavaScriptSerializer js = new JavaScriptSerializer(); //实例化一个能够序列化数据的类

ToJsonMy3 list = js.Deserialize<ToJsonMy3>(json); //将json数据转化为对象类型并赋值给list

string result = list.result;

string res_info = list.res_info;

string order_num = list.queryorder_info.order_num;

List<orderdetail> orderdetail = list.queryorder_info.orderdetail;

string CFTUin = orderdetail[0].CFTUin;

string HotelName = orderdetail[0].HotelName;

string ListID = orderdetail[1].ListID;

string State = orderdetail[2].State;

}

c# json处理(转)的更多相关文章

  1. 使用TSQL查询和更新 JSON 数据

    JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...

  2. 【疯狂造轮子-iOS】JSON转Model系列之二

    [疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...

  3. 【疯狂造轮子-iOS】JSON转Model系列之一

    [疯狂造轮子-iOS]JSON转Model系列之一 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 之前一直看别人的源码,虽然对自己提升比较大,但毕竟不是自己写的,很容易遗 ...

  4. Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)

    背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...

  5. .NET Core系列 : 2 、project.json 这葫芦里卖的什么药

    .NET Core系列 : 1..NET Core 环境搭建和命令行CLI入门 介绍了.NET Core环境,本文介绍.NET Core中最重要的一个配置文件project.json的相关内容.我们可 ...

  6. 一个粗心的Bug,JSON格式不规范导致AJAX错误

    一.事件回放  今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...

  7. JSON.parse()和JSON.stringify()

    1.parse 用于从一个字符串中解析出json 对象.例如 var str='{"name":"cpf","age":"23&q ...

  8. json与JavaScript对象互换

    1,json字符串转化为JavaScript对象: 方法:JSON.parse(string) eg:var account = '{"name":"jaytan&quo ...

  9. .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...

  10. WebApi接口 - 响应输出xml和json

    格式化数据这东西,主要看需要的运用场景,今天和大家分享的是webapi格式化数据,这里面的例子主要是输出json和xml的格式数据,测试用例很接近实际常用情况:希望大家喜欢,也希望各位多多扫码支持和点 ...

随机推荐

  1. 打包ipa分发给测试机安装步骤

    1.确定可以打包的Mac电脑,即该Mac电脑已经具备可以打包的权限. 需要上传一份Mac电脑的描述文件,即csr文件. 2.创建bundle id 3.添加测试设备 4.生成证明描述文件 5.Xcod ...

  2. web基础-web工作原理,http协议,浏览器缓存

    1,web工作原理 2,http协议 3,浏览器缓存 4,cookie和session -------------------------------------------------------- ...

  3. Javascript数组中shift()和push(),unshift()和pop()操作方法使用

    Javascript为数组专门提供了push和pop()方法,以便实现类似栈的行为.来看下面的例子: var colors=new Array();       //创建一个数组 var count= ...

  4. SQL游标+递归查询客户子客户转换率

    ALTER PROCEDURE [dbo].[Account3YearsConversion ] as DECLARE @AccountId UNIQUEIDENTIFIER , @yearbefor ...

  5. 看到当年自己学SQL Server 的笔记

    数据库 数据量DataBase,不同类型的数据应该放到不同的数据库中, .便于对各个数据类别进行个性管理 .避免命名冲突 .安全性更高; table(表):数据库中的关系指的就是表; 一张表就是一个类 ...

  6. Ubuntu 14.04安装Sogou输入法

    在http://pinyin.sogou.com/linux/?r=pinyin页面可下载对应的的deb包.在http://pinyin.sogou.com/linux/help.php页面有搜狗输入 ...

  7. org.hibernate.QueryException: could not resolve property: address of:

    Hibernate: select count(*) as y0_ from test.course this_ org.hibernate.QueryException: could not res ...

  8. 十全大补DBA学习资源

    学习oracle已经有1年多了,从开始的菜鸟到现在的DBA,一路走来~迷茫过.兴奋过.但我仍然会在DBA的道路上走下去!oracle要学的有很多,会遇到很多难题,网上有很多学习oracle好的学习资料 ...

  9. SQL 语句中按照in语句原有的顺序进行排序

    Access: ,,) order by instr(',1,5,3,',','&;id&;',') MSSQL: ,,) )))+',',',1,5,3,') MySQL: ,,) ...

  10. 摩根斯坦利 - 2016年09月8日 面试题 - HashMap

    摩根斯坦利 - 2016年09月8日 面试题: 给定一个 Map<Person, Object> map = new HashMap<Person, Object>(); 放入 ...