前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >linq to xml复习

linq to xml复习

作者头像
菩提树下的杨过
发布2018-01-23 11:22:06
6270
发布2018-01-23 11:22:06
举报

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

代码语言:js
复制
 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的各种元素都用到了

代码语言:js
复制
<?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

代码语言:js
复制
 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.带循环的"复杂"创建节点

代码语言:js
复制
 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内容如下:

代码语言:js
复制
 <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>

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2009-10-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档