linq to xml复习

时间:2022-04-23
本文章向大家介绍linq to xml复习,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

虽然linq to xml随着.net framework3.0一起发布N久了,但因为自己以前参考网上的代码封装了一个xml操作类(当时linq to xml还没出来,这个封闭工具类一直也用得很顺手),所以在项目中也几乎极少用linq to xml,最近业余时间学习silverlight,原来针对winform/webform开发写的一些工具库部分要作修改才能用于silverlight,懒得一一移植了,干脆直接用.net内置的得了,何况自己再写一个,也还是这些玩意儿,有现成的不用白不用,整理了一些demo代码,贴在这里日后备用 1.简单创建xml

 XElement xml = new XElement("Data",//创建Data根节点
                   new XElement("item",//创建Data下的子节点item
                       new XAttribute("src", "http://www.baidu.com/logo.gif"),//创建属性
                       new XAttribute("url", "http://www.baidu.com/")
                       ),
                   new XElement("item",
                       new XAttribute("src", "http://www.yahoo.com.cn/logo.gif"),
                       new XAttribute("url", "http://www.yahoo.com.cn/"),
                       new XComment("item's comment"),//注释
                       new XText("items's text"),//节点文本
                       new XCData("<b>CData Test!</b>")//CData文本
                       ),
                   new XElement("item",
                       new XElement("sub",
                             new XAttribute("type", "string")
                             ),
                       new XElement("id",
                             new XText("10001")
                             )
                   )
              );
           //xml.Save(Server.MapPath("demo.xml"));//保存为文件

以上代码将创建以下内容的xml,基本上xml的各种元素都用到了

<?xml version="1.0" encoding="utf-8"?>
 <Data>
 <item src="http://www.baidu.com/logo.gif" url="http://www.baidu.com/" />
 <item src="http://www.yahoo.com.cn/logo.gif" url="http://www.yahoo.com.cn/">
   <!--item's comment-->items's text<![CDATA[<b>CData Test!</b>]]></item>
 <item>
   <sub type="string" />
   <id>10001</id>
 </item>
</Data>

2.查询xml

 XElement root = XElement.Load(Server.MapPath("demo.xml"));
 //找出item元素中有属性src的节点
 //IEnumerable<XElement> query = from c in root.Elements("item")
 //                              where c.Attributes("src").Count() > 0
 //                              select c;            
 /**/////当然也可以写成lambda表达式
 //var query = root.Elements("item").Where(c => c.Attributes("src").Count() > 0);
//如果您熟悉xpath语法,可以写得更精简,这也是我最喜欢的方式
var query = root.XPathSelectElements("item[@src]");
foreach (var item in query)
{
   Response.Write(HttpUtility.HtmlEncode(item.ToString()) + "<br/>");
}

//找出item元素中的有属性src,且包含baidu的节点
//var query = from c in root.Elements("item")
//            where c.Attributes("src").Count() > 0 && ((string)c.Attribute("src")).Contains("baidu")
//            select c;                            
   
/**/////等同于以下的lambda写法
//var query = root.Elements("item").Where(c => c.Attributes("src").Count() > 0 && ((string)c.Attribute("src")).Contains("baidu"));
/**/////用xpath语法更省事
//var query = root.XPathSelectElements("item[@src][contains(@src,'baidu')]");

 注:如果使用XPath语法,先要using System.Xml.XPath;

3.带循环的"复杂"创建节点

 XElement root = new XElement("data");
 var _arr = "y j m y z z @ 1 2 6 . c o m".Split(' ');
 foreach (string c in _arr)
 {
   XElement item = new XElement("item",
               new XAttribute("value", c)
           );
    root.Add(item);
}

root内容如下:

 <data>
 <item value="y" />
 <item value="j" />
 <item value="m" />
 <item value="y" />
 <item value="z" />
 <item value="z" />
 <item value="@" />
 <item value="1" />
 <item value="2" />
 <item value="6" />
 <item value="." />
 <item value="c" />
 <item value="o" />
 <item value="m" />
</data>

 转载请注明出自"菩提树下的杨过"