源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

解析linq to xml操作XML的示例分析

  • 时间:2020-05-12 01:20 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:解析linq to xml操作XML的示例分析
.Net中的System.Xml.Linq命名空间提供了linq to xml的支持。这个命名空间中的XDocument,XElement以及XText,XAttribute提供了读写xml文档的关键方法。 [b]1. 使用linq to xml写xml: [/b]使用XDocument的构造函数可以构造一个Xml文档对象;使用XElement对象可以构造一个xml节点元素,使用XAttribute构造函数可以构造元素的属性;使用XText构造函数可以构造节点内的文本。 如下实例代码:
[u]复制代码[/u] 代码如下:
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:
[u]复制代码[/u] 代码如下:
<?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要方便很多。 [b]2. 使用linq to xml 读取xml [/b]Linq是从集合中查询对象,在linq to xml中的集合是通过XElement的Elements(),Elements(string name),以及Descendants、DescendantsAndSelf、Ancestors、AncestorsAndSelf的几个重载方法中获得。 获得XElement集合之后,可以通过XElement的Attribute(string name)方法获得元素的属性值,可以通过XElement的Value属性获得节点的文本值;使用linq就可以方便的做查询,做筛选排序了 还是上例中的xml,我们要读取root的所有字节点,并打印出来,如下代码:
[u]复制代码[/u] 代码如下:
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();     } }
[b]3. Linq to xml简单的应用 [/b]应用需求: 读取博客园的rss,然后在页面上输出最新的10篇博客信息 实现要点: 通过XDocument的Load静态方法载入Xml,通过linq查询最新10条数据 代码如下:
[u]复制代码[/u] 代码如下:
<%@ Page Language="C#" AutoEventWireup="true" %> <script runat="server">     protected override void OnLoad(EventArgs e)     {         //实际应用,通过读取博客园的RSS生成Html代码显示最新的博客列表         //使用XDocument的Load静态方法载入Xml         var rssXDoc = XDocument.Load("http://www.1sucai.cn");         //使用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越来越简单了。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部