虽然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>
转载请注明出自"菩提树下的杨过"