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构造函数可以构造节点内的文本。
如下实例代码: 
| classProgram{    staticvoidMain(string[] args)    {                   varxDoc = newXDocument(newXElement( "root",            newXElement("dog",                newXText("dog said black is a beautify color"),                newXAttribute("color", "black")),            newXElement("cat"),            newXElement("pig", "pig is great")));        //xDoc输出xml的encoding是系统默认编码,对于简体中文操作系统是gb2312        //默认是缩进格式化的xml,而无须格式化设置        xDoc.Save(Console.Out);        Console.Read();    }} | 
上面代码将输出如下Xml: 
| <?xmlversion="1.0" encoding="gb2312"?><root>  <dogcolor="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的所有字节点,并打印出来,如下代码:
| classProgram{    staticvoidMain(string[] args)    {                   varxDoc = newXDocument(newXElement( "root",            newXElement("dog",                newXText("dog said black is a beautify color"),                newXAttribute("color", "black")),            newXElement("cat"),            newXElement("pig", "pig is great")));        //xDoc输出xml的encoding是系统默认编码,对于简体中文操作系统是gb2312        //默认是缩进格式化的xml,而无须格式化设置        xDoc.Save(Console.Out);        Console.WriteLine();        varquery = fromitem inxDoc.Element( "root").Elements()                    selectnew                    {                        TypeName    = item.Name,                        Saying      = item.Value,                        Color       = item.Attribute("color") == null?(string)null:item.Attribute("color").Value                    };        foreach(varitem inquery)        {            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" %><scriptrunat="server">    protected override void OnLoad(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><!DOCTYPEhtml PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><headrunat="server">    <title>Linq to Xml 实例</title></head><body>    <ol>        <asp:RepeaterID="repeaterBlogs" EnableViewState="false" runat="server">            <ItemTemplate>                <li><spanstyle="float: right">                    <%#Eval("PostTime") %></span><ahref="<%#Eval("Url") %>"><%#Eval("Title") %></a></li>            </ItemTemplate>        </asp:Repeater>    </ol></body></html> | 
C#的发展让读写Xml越来越简单了。
C#处理Xml的相关随笔:
 
                     
                    
                 
                    
                 
                
            
         
 
         浙公网安备 33010602011771号
浙公网安备 33010602011771号