LinQ To XML——用LinQ查询XML

将一个已知的XML放到XDocument 对象当中使用LINQ 查询非常的容易,下面是一个例子。

查找XML文档中的所有PERSONA元素显示结果个数,并遍历输出其值

 

public   void  MyDescendants()
        {
            XDocument xdoc 
=  XDocument.Load(Server.MapPath( " hamlet.xml " ));
            
// 查找元素名为PERSONA 的元素
            var query  =  from people  in  xdoc.Descendants( " PERSONA " )
                        select people.Value;
            
// people 是符合条件元素结果集 而people.Value;就是这个结果集的所有元素的值的序列
            Response.Write(query.Count()  +   "  个玩家被找到。 " );

            Response.Write(
" <p />他们是: <p /> " );

            
foreach  (var item  in  query)
            {
                
// 输出他们的值
                Response.Write( item  +   " <br /> " );

            }
        } 
通过URL 找到一个网络上的RSS XML文档,并查询。

public   void  MyRSS()
       {
           
// 通过下面的代码你可以看到一个简单的网页RSS阅读器
           XDocument xdoc  =  XDocument.Load( @" http://www.cnblogs.com/TerryFeng/rss " );
           
// 找到channel元素集合
           var query  =  from rssFeed  in  xdoc.Descendants( " channel " )
                       select 
new
                       {
                           Title 
=  rssFeed.Element( " title " ).Value, // 获取其下的title元素的值组成新结果集匿名对象的属性
                           Description  =  rssFeed.Element( " description " ).Value, // 获取其下的description元素的值组成新结果集匿名对象的属性
                           Link  =  rssFeed.Element( " link " ).Value, // 获取其下的link元素的值组成新结果集匿名对象的属性
                       };

           
foreach  (var item  in  query)
           {
               Response.Write(
" 博客:  "   +  item.Title  +   " <br /> " );
               Response.Write(
" 描述:  "   +  item.Description  +   " <br /> " );
               Response.Write(
" 地址:  "   +  item.Link  +   " <br /><p /> " );
           }

           
// 第二个查询,查询文档中的item元素,每个项目就是一个博客随笔
           var queryPosts  =  from myPosts  in  xdoc.Descendants( " item " )
                            select 
new
                            {
                                Title 
=  myPosts.Element( " title " ).Value,
                                Published 
=  DateTime.Parse( myPosts.Element( " pubDate " ).Value),
                                Description 
=  myPosts.Element( " description " ).Value,
                                Url 
=  myPosts.Element( " link " ).Value,
                                Comments 
=  myPosts.Element( " comments " ).Value,
                            };

           
foreach  (var item  in  queryPosts)
           {
               Response.Write(
" 标题:  "   +  item.Title  +   " <br /> " );
               Response.Write(
" 发布日期:  "   +  item.Published  +   " <br /> " );
               Response.Write(
" 链接:  "   +  item.Url  +   " <br /> " );
               Response.Write(
" 内容:  "   +  item.Description  +   " <br /> " );
               Response.Write(
" 注释:  "   +  item.Comments  +   " <br /><p /> " );
               

           }

           Console.ReadLine();
     
 }
        
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值