linq to xml操作XML,这是转的大神的,自己学习了,也希望你们也能学习一下

linq to xml操作XML

LINQ to XML提供了更方便的读写xml方式。前几篇文章的评论中总有朋友提,你为啥不用linq to xml?现在到时候了,linq to xml出场了。

.Net中的System.Xml.Linq命名空间提供了linq to xml的支持。这个命名空间中的XDocumentXElement以及XTextXAttribute提供了读写xml文档的关键方法。

1. 使用linq to xmlxml(创建)

使用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输出xmlencoding是系统默认编码,对于简体中文操作系统是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 xmlXmlDocumentXmlWriter要方便很多。

2. 使用linq to xml 读取xml

Linq是从集合中查询对象,在linq to xml中的集合是通过XElementElements(),Elements(string name),以及DescendantsDescendantsAndSelfAncestorsAncestorsAndSelf的几个重载方法中获得。获得XElement集合之后,可以通过XElementAttribute(string name)方法获得元素的属性值,可以通过XElementValue属性获得节点的文本值;使用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输出xmlencoding是系统默认编码,对于简体中文操作系统是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篇博客信息

实现要点: 通过XDocumentLoad静态方法载入Xml,通过linq查询最新10条数据

代码如下:

<%@ Page Language="C#" AutoEventWireup="true" %> 

<script runat="server"> 

    protected override void OnLoad(EventArgs e) 

    {          //实际应用,通过读取博客园的RSS生成Html代码显示最新的博客列表 

        //使用XDocumentLoad静态方法载入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="<%#Eval("Url") %>"><%#Eval("Title") %></a></li> 

            </ItemTemplate> 

       </asp:Repeater> 

    </ol>  </body> 

</html>

C#的发展让读写Xml越来越简单了。

最后推荐一下以前写的一个LINQ to SQL的系列文章

posted @ 2011-07-21 09:50  八神吻你  阅读(506)  评论(0编辑  收藏  举报