lambda select和where区别
本文用一个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()});
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端