首页 > 代码库 > C#操作Xml:linq to xml操作XML
C#操作Xml:linq to xml操作XML
LINQ to XML提供了更方便的读写xml方式。前几篇文章的评论中总有朋友提,你为啥不用linq to xml?现在到时候了,linq to xml出场了。
.Net中的System.Xml.Linq命名空间提供了linq to xml的支持。这个命名空间中的XDocument,XElement以及XText,XAttribute提供了读写xml文档的关键方法。
1. 使用linq to xml写xml:
使用XDocument的构造函数可以构造一个Xml文档对象;使用XElement对象可以构造一个xml节点元素,使用XAttribute构造函数可以构造元素的属性;使用XText构造函数可以构造节点内的文本。
如下实例代码:
?
class Program { static void Main( string [] args) { var xDoc = new XDocument( new XElement( "root" , new XElement( "dog" , new XText( "dog said black is a beautify color" ), new XAttribute( "color" , "black" )), new XElement( "cat" ), new XElement( "pig" , "pig is great" ))); //xDoc输出xml的encoding是系统默认编码,对于简体中文操作系统是gb2312 //默认是缩进格式化的xml,而无须格式化设置 xDoc.Save(Console.Out); Console.Read(); } } |
上面代码将输出如下Xml:
?
<? xml version="1.0" encoding="gb2312"?> < root > < dog color="black">dog said black is a beautify color</ dog > < cat /> < pig >pig is great</ pig > </ root > |
可以看出linq to xml比XmlDocument和XmlWriter要方便很多。
2. 使用linq to xml 读取xml
Linq是从集合中查询对象,在linq to xml中的集合是通过XElement的Elements(),Elements(string name),以及Descendants、DescendantsAndSelf、Ancestors、AncestorsAndSelf的几个重载方法中获得。
获得XElement集合之后,可以通过XElement的Attribute(string name)方法获得元素的属性值,可以通过XElement的Value属性获得节点的文本值;使用linq就可以方便的做查询,做筛选排序了
还是上例中的xml,我们要读取root的所有字节点,并打印出来,如下代码:
?
class Program { static void Main( string [] args) { var xDoc = new XDocument( new XElement( "root" , new XElement( "dog" , new XText( "dog said black is a beautify color" ), new XAttribute( "color" , "black" )), new XElement( "cat" ), new XElement( "pig" , "pig is great" ))); //xDoc输出xml的encoding是系统默认编码,对于简体中文操作系统是gb2312 //默认是缩进格式化的xml,而无须格式化设置 xDoc.Save(Console.Out); Console.WriteLine(); var query = from item in xDoc.Element( "root" ).Elements() select new { TypeName = item.Name, Saying = item.Value, Color = item.Attribute( "color" ) == null ?( string ) null :item.Attribute( "color" ).Value }; foreach ( var item in query) { Console.WriteLine( "{0} ‘s color is {1},{0} said {2}" ,item.TypeName,item.Color?? "Unknown" ,item.Saying?? "nothing" ); } Console.Read(); } } |
3. Linq to xml简单的应用
应用需求: 读取博客园的rss,然后在页面上输出最新的10篇博客信息
实现要点: 通过XDocument的Load静态方法载入Xml,通过linq查询最新10条数据
代码如下:
?
<%@ Page Language="C#" AutoEventWireup="true" %> < script runat="server"> protected override void onl oad(EventArgs e) { //实际应用,通过读取博客园的RSS生成Html代码显示最新的博客列表 //使用XDocument的Load静态方法载入Xml //玉开技术博客 http://www.cnblogs.com/yukaizhao var rssXDoc = XDocument.Load("http://www.cnblogs.com/rss"); //使用linq to xml查询前10条新博客 var queryBlogs = (from blog in rssXDoc.Descendants("item") select new { Title = blog.Element("title").Value, Url = blog.Element("link").Value, PostTime = DateTime.Parse(blog.Element("pubDate").Value) }).Take(20); repeaterBlogs.DataSource = queryBlogs; repeaterBlogs.DataBind(); base.OnLoad(e); } </ script > <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> < html xmlns="http://www.w3.org/1999/xhtml"> < head runat="server"> < title >Linq to Xml 实例</ title > </ head > < body > < ol > < asp:Repeater ID="repeaterBlogs" EnableViewState="false" runat="server"> < ItemTemplate > < li >< span style="float: right"> <%#Eval("PostTime") %></ span >< a href="http://www.mamicode.com/<%#Eval("Url") %>"><%#Eval("Title") %></ a ></ li > </ ItemTemplate > </ asp:Repeater > </ ol > </ body > </ html > |
C#的发展让读写Xml越来越简单了。
C#处理Xml的相关随笔:
1.通过XmlDocument读写Xml文档
2.使用XmlReader读Xml,使用XmlWriter写Xml
3.使用Linq to xml存取XML
4.通过XmlScheme定义固定格式xml文档
5.Xml序列化或者反序列化类
6.通过XPath查找Xml节点
7.通过Xslt转化Xml格式
C#操作Xml:linq to xml操作XML
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。