C#对XML、JSON等格式的解析

C#对XML、JSON等格式的解析

一、C#对XML格式数据的解析

1、用XMLDocument来解析

[csharp] view plain copy
  1. XmlDocument xmlDocument = new XmlDocument();  
  2. xmlDocument.Load("test.xml");  
  3.   
  4. //创建新节点   
  5. XmlElement nn = xmlDocument.CreateElement("image");  
  6. nn.SetAttribute("imageUrl""6.jpg");  
  7.   
  8. XmlNode node = xmlDocument.SelectSingleNode("content/section/page/gall/folder");//定位到folder节点  
  9. node.AppendChild(nn);//附加新节点  
  10.   
  11. //保存  
  12. xmlDocument.Save("test.xml");  

2、用Linq to XML来解析

可以通过遍历,来获得你想要的节点的内容或属性

[csharp] view plain copy
  1. XElement root = XElement.Load("test.xml");  
  2. foreach (XAttribute att in root.Attributes())  
  3. {  
  4.     root.Add(new XElement(att.Name, (string)att));  
  5. }  
  6. Console.WriteLine(root);  

3、附一个详细点的例子

比如要解析如下的xml文件,将其转化为Ilist对象。

[html] view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <Car>  
  3.   <carcost>  
  4.     <ID>20130821133126</ID>  
  5.     <uptime>60</uptime>  
  6.     <downtime>30</downtime>  
  7.     <price>0.4</price>  
  8.   </carcost>  
  9.   <carcost>  
  10.     <ID>20130821014316</ID>  
  11.     <uptime>120</uptime>  
  12.     <downtime>60</downtime>  
  13.     <price>0.3</price>  
  14.   </carcost>  
  15.   <carcost>  
  16.     <ID>20130822043127</ID>  
  17.     <uptime>30</uptime>  
  18.     <downtime>0</downtime>  
  19.     <price>0.5</price>  
  20.   </carcost>  
  21.   <carcost>  
  22.     <ID>20130822043341</ID>  
  23.     <uptime>120以上!</uptime>  
  24.     <downtime>120</downtime>  
  25.     <price>0.2</price>  
  26.   </carcost>  
  27. </Car>  
在控制台应用程序中输入如下代码即可。
[csharp] view plain copy
  1. class Program  
  2. {  
  3.     static void Main(string[] args)  
  4.     {  
  5.         IList<CarCost> resultList = new List<CarCost>();  
  6.   
  7.         XmlDocument xmlDocument = new XmlDocument();  
  8.         xmlDocument.Load("test.xml");  
  9.   
  10.         XmlNodeList xmlNodeList = xmlDocument.SelectSingleNode("Car").ChildNodes;  
  11.         foreach (XmlNode list in xmlNodeList)  
  12.         {  
  13.             CarCost carcost = new CarCost  
  14.             (  
  15.                 list.SelectSingleNode("ID").InnerText,  
  16.                 list.SelectSingleNode("uptime").InnerText,  
  17.                 list.SelectSingleNode("downtime").InnerText,  
  18.                 float.Parse(list.SelectSingleNode("price").InnerText)  
  19.             );  
  20.             resultList.Add(carcost);  
  21.         }  
  22.   
  23.         IEnumerator enumerator = resultList.GetEnumerator();  
  24.         while (enumerator.MoveNext())  
  25.         {  
  26.             CarCost carCost = enumerator.Current as CarCost;  
  27.             Console.WriteLine(carCost.ID + " " + carCost.UpTime + " " + carCost.DownTime + " " + carCost.Price);  
  28.         }  
  29.     }  
  30. }  
  31.   
  32. public class CarCost  
  33. {  
  34.     public CarCost(string id, string uptime, string downtime, float price)  
  35.     {  
  36.         this.ID = id;  
  37.         this.UpTime = uptime;  
  38.         this.DownTime = downtime;  
  39.         this.Price = price;  
  40.     }  
  41.     public string ID { getset; }  
  42.     public string UpTime { getset; }  
  43.     public string DownTime { getset; }  
  44.     public float Price { getset; }  
  45. }  

二、C#对JSON格式数据的解析

引用Newtonsoft.Json.dll文件,来解析。

比如:有个要解析的JSON字符串

[{"TaskRoleSpaces":"","TaskRoles":"","ProxyUserID":"5d9ad5dc1c5e494db1d1b4d8d79b60a7","UserID":"5d9ad5dc1c5e494db1d1b4d8d79b60a7","UserName":"姓名","UserSystemName":"2234","OperationName":"送合同负责人","OperationValue":"同意","OperationValueText":"","SignDate":"2013-06-19 10:31:26","Comment":"同意","FormDataHashCode":"","SignatureDivID":""},{"TaskRoleSpaces":"","TaskRoles":"","ProxyUserID":"2c96c3943826ea93013826eafe6d0089","UserID":"2c96c3943826ea93013826eafe6d0089","UserName":"姓名2","UserSystemName":"1234","OperationName":"送合同负责人","OperationValue":"同意","OperationValueText":"","SignDate":"2013-06-20 09:37:11","Comment":"同意","FormDataHashCode":"","SignatureDivID":""}]

首先定义个实体类:

[csharp] view plain copy
  1. public class JobInfo  
  2. {  
  3.     public string TaskRoleSpaces { getset; }  
  4.     public string TaskRoles { getset; }  
  5.     public string ProxyUserID { getset; }  
  6.     public string UserID { getset; }  
  7.     public string UserName { getset; }  
  8.     public string UserSystemName { getset; }  
  9.     public string OperationName { getset; }  
  10.     public string OperationValue { getset; }  
  11.     public string OperationValueText { getset; }  
  12.     public DateTime SignDate { getset; }  
  13.     public string Comment { getset; }  
  14.     public string FormDataHashCode { getset; }  
  15.     public string SignatureDivID { getset; }  
  16. }  
然后在控制台Main函数内部输入如下代码:

[csharp] view plain copy
  1. string json = @"[{'TaskRoleSpaces':'','TaskRoles':'','ProxyUserID':'5d9ad5dc1c5e494db1d1b4d8d79b60a7','UserID':'5d9ad5dc1c5e494db1d1b4d8d79b60a7','UserName':'姓名','UserSystemName':'2234','OperationName':'送合同负责人','OperationValue':'同意','OperationValueText':'','SignDate':'2013-06-19 10:31:26','Comment':'同意','FormDataHashCode':'','SignatureDivID':''},{'TaskRoleSpaces':'','TaskRoles':'','ProxyUserID':'2c96c3943826ea93013826eafe6d0089','UserID':'2c96c3943826ea93013826eafe6d0089','UserName':'姓名2','UserSystemName':'1234','OperationName':'送合同负责人','OperationValue':'同意','OperationValueText':'','SignDate':'2013-06-20 09:37:11','Comment':'同意','FormDataHashCode':'','SignatureDivID':''}]  
  2. ";  
  3.    
  4.             List<JobInfo> jobInfoList = JsonConvert.DeserializeObject<List<JobInfo>>(json);  
  5.    
  6.             foreach (JobInfo jobInfo in jobInfoList)  
  7.             {  
  8.                 Console.WriteLine("UserName:" + jobInfo.UserName + "UserID:" + jobInfo.UserID);  
  9.             }  

这样就可以正常输出内容了。

我想肯定有人会问,如果有多层关系的json字符串该如何处理呢?没关系,一样的处理。

比如如何解析这个json字符串:[{'phantom':true,'id':'20130717001','data':{'MID':1019,'Name':'aaccccc','Des':'cc','Disable':'启用','Remark':'cccc'}}]  ?

首先还是定义实体类:

[csharp] view plain copy
  1. public class Info  
  2. {  
  3.     public string phantom { getset; }  
  4.     public string id { getset; }  
  5.     public data data { getset; }  
  6. }  
  7.   
  8. public class data  
  9. {  
  10.     public int MID { getset; }  
  11.     public string Name { getset; }  
  12.     public string Des { getset; }  
  13.     public string Disable { getset; }  
  14.     public string Remark { getset; }  
  15. }  
然后在main方法里面,键入:
[csharp] view plain copy
  1. string json = @"[{'phantom':true,'id':'20130717001','data':{'MID':1019,'Name':'aaccccc','Des':'cc','Disable':'启用','Remark':'cccc'}}]";  
  2. List<Info> infoList = JsonConvert.DeserializeObject<List<Info>>(json);  
  3.   
  4. foreach (Info info in infoList)  
  5. {  
  6.     Console.WriteLine("id:" + info.data.MID);  
  7. }  
按照我们的预期,应该能够得到1019的结果。

截图为证:

另外,对于有些json格式不是标准的,可以使用通用的方法进行解析。

[csharp] view plain copy
  1. string jsonText = @" {'Count':1543,'Items':[{'UnitID':6119,'UnitName':'C'}]}";  
  2. JsonReader reader = new JsonTextReader(new StringReader(jsonText));  
  3. while (reader.Read())  
  4. {  
  5.     Console.WriteLine(reader.TokenType + "\t\t" + reader.ValueType + "\t\t" + reader.Value);  
  6. }  
附Newtonsoft.Json.dll下载地址: 下载吧

你可能感兴趣的:(C#对XML、JSON等格式的解析)