码迷,mamicode.com
首页 > 其他好文 > 详细

lambda select和where区别

时间:2018-10-08 15:55:52      阅读:388      评论:0      收藏:0      [点我收藏+]

标签:字段   his   技术分享   private   分享图片   inpu   coding   encoding   分享   

本文用一个linq to xml语法作为示例,以下是用来操作的xml:
<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<!--This is a comment.Just input what you want to say.-->
<UsersInfomation>
  <User ID="1">
    <Name>Alex</Name>
    <Hometown>HRB</Hometown>
    <Age>22</Age>
  </User>
  <User ID="2">
    <Name>Fu</Name>
    <Hometown>SY</Hometown>
    <Age>27</Age>
  </User>
  <User ID="3">
    <Name>Abe</Name>
    <Hometown>HRB</Hometown>
    <Age>24</Age>
  </User>
</UsersInfomation>

在一个输出台控制程序中加载xml,并调用方法:
XElement xd = XElement.Load(@"D:\1\userInfomation.xml");
GetHometown(xd);
Console.WriteLine();


//统计hometown为HRB的人数
private static void GetHometown(XElement xe)
{
    //Select用于选择输出(不能作为筛选条件),比如:.Select(s=>s)将输出一个实体;.Select(s=>s.Value)将输出值;
    //而下面的代码将输出的是bool类型:
    var hometown = xe.Descendants("Hometown").Select(s => s.Value == "HRB");
    //输出为:

技术分享图片
//可以看出,输出的行数是全部行,只是输出的内容是bool,这是由Select子句决定的。

 
    //Where扩展方法才是用来进行条件筛选(虽然它返回的也是bool值,但作用和Select不一样)
    //等同于:var hometown = xe.Descendants("Hometown").Where(s => s.Value == "HRB").Select(s => s);
    var hometown = xe.Descendants("Hometown").Where(s => s.Value == "HRB");
    //输出为:

技术分享图片
//可以看出,输出了符合条件的行。

    //查询语法(等同于上一句)
    //var hometown = from h in xe.Descendants("Hometown")
    //               where h.Value == "HRB"
    //               select h;

    int count = 0;
    foreach (var h in hometown)
    {
        Console.WriteLine(h);
        count++;
    }
    Console.WriteLine("==============>"+count);
}

------------------------------ Select用法续 《Pro ASP.NET MVC 3 Framework》p529---------------------
作用:
1、用来过滤要显示的字段
2、定义字段要显示的样式
如:
var formattedData=data.Select(m=>new { ClientName=m.ClientName,Date=m.Date.ToShortDateString()});

lambda select和where区别

标签:字段   his   技术分享   private   分享图片   inpu   coding   encoding   分享   

原文地址:https://www.cnblogs.com/zhaow/p/9754621.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!