C# Linq 学习笔记
刚刚学习了 Siki老师 的C#教程Linq部分,以下是笔记
需要引用命名空间
using System.Linq;
然后我们需要准备数据
武林高手类
/// <summary>
/// 武林高手类
/// </summary>
class MartialArtsMaster
{
public int ID { get; set; }
public string Name { get; set; }
public int Age { get; set; }
public string MenPai { get; set; }
public string Kongfu { get; set; }
public int Level { get; set; } public override string ToString()
{
return string.Format("{0}--{1}--{2}--{3}--{4}--{5}", ID, Name, Age, MenPai, Kongfu, Level);
}
}
武林绝学类
class Kongfu
{
public int ID { get; set; }
public string Name { get; set; }
public int Power { get; set; } public override string ToString()
{
return string.Format("{0}--{1}--{2}", ID, Name, Power);
}
}
Main方法里的武林高手列表和武林绝学列表
List<MartialArtsMaster> masterList = new List<MartialArtsMaster>()
{
new MartialArtsMaster() { ID = , Name = "黄蓉", Age = , MenPai = "丐帮", Kongfu = "打狗棒法", Level = },
new MartialArtsMaster() { ID = , Name = "洪七公", Age = , MenPai = "丐帮", Kongfu = "打狗棒法", Level = },
new MartialArtsMaster() { ID = , Name = "郭靖", Age = , MenPai = "丐帮", Kongfu = "降龙十八掌", Level = },
new MartialArtsMaster() { ID = , Name = "任我行", Age = , MenPai = "明教", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "东方不败", Age = , MenPai = "明教", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "林平之", Age = , MenPai = "华山", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "岳不群", Age = , MenPai = "华山", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "令狐冲", Age = , MenPai = "华山", Kongfu = "独孤九剑", Level = },
new MartialArtsMaster() { ID = , Name = "梅超风", Age = , MenPai = "桃花岛", Kongfu = "九阴真经", Level = },
new MartialArtsMaster() { ID = , Name = "黄药师", Age = , MenPai = "梅花岛", Kongfu = "弹指神功", Level = },
new MartialArtsMaster() { ID = , Name = "风清扬", Age = , MenPai = "华山", Kongfu = "独孤九剑", Level = },
};
List<Kongfu> kongfuList = new List<Kongfu>()
{
new Kongfu() {ID=,Name="打狗棒法",Power= },
new Kongfu() {ID=,Name="降龙十八掌",Power= },
new Kongfu() {ID=,Name="葵花宝典",Power= },
new Kongfu() {ID=,Name="独孤九剑",Power= },
new Kongfu() {ID=,Name="九阴真经",Power= },
new Kongfu() {ID=,Name="弹指神功",Power= }
};
表达式基本写法
var res = from m in masterList
where m.MenPai == "丐帮"//条件,布尔表达式
select m.Name;//返回名字的集合
事实上,条件语句是可以用一个委托代替的,如下面的代码
delegate bool BoolDel(MartialArtsMaster mar);
var res = from m in masterList
where boolDel(m)
select m.Name;
也可以使用扩展方法的方式进行查询
var res = masterList.Where(new Func<MartialArtsMaster, bool>(boolDel));
接着我用下面的代码输出
Console.WriteLine("找到 " + res.Count() + " 条记录:");
foreach(var item in res)
{
Console.WriteLine(item);
}

联合查询
使用多个from in 进行查询
var res = from m in masterList
from k in kongfuList
where m.Kongfu == k.Name && k.Power >
select new { master = m, kongfu = k };
使用扩展方法进行联合查询
var res = masterList.SelectMany(m => kongfuList, (m, k) => new { master = m, kongfu = k })
.Where(x => x.master.Kongfu == x.kongfu.Name && x.kongfu.Power > );

使用Join on 进行联合查询
var res = from m in masterList
join k in kongfuList on m.Kongfu equals k.Name
select new { master = m, kongfu = k };

对查询结果进行排序
var res = from m in masterList
orderby m.Level, m.Age descending //级别升序,年龄降序
select m;
扩展方法形式
var res = masterList.OrderBy(m => m.Level).ThenByDescending(m => m.Age);

分组查询
var res = from k in kongfuList
join m in masterList on k.Name equals m.Kongfu
into groups//根据 k 分组
orderby groups.Count()
select new { kongfu = k, count = groups.Count() };

按照自身字段分组
var res = from m in masterList
group m by m.MenPai into g
select new { MenPai = g.Key, Count = g.Count() };

量词操作
其实就是查询这个集合里是否包含我要查的东西
Console.WriteLine(masterList.Any(m => m.MenPai == "少林寺"));//任一满足,则返回true
Console.WriteLine(masterList.All(m => m.MenPai == "丐帮"));//所有满足,则返回true
第一行查询武林高手列表里有没有少林寺的,第二行查询列表里的是不是都是丐帮的

C# Linq 学习笔记的更多相关文章
- linq学习笔记
最近在学习linq的一些基础知识,看了c#高级编程及阅读了园子内部几篇优秀的博文,有所体会,感觉应该记录下来,作为以后复习使用.都是一些最基础的知识,大致分为三个部分:linq预备知识:linq查询: ...
- (转)Linq学习笔记
写在前面 最近在看Linq,在博客园看到这篇文章,写的通俗易懂,转来和大家一起做个分享.原文地址http://www.cnblogs.com/goscan/archive/2011/05/05/Lin ...
- C#之Linq学习笔记【转】
写在前面 其实在09年就已经学习过Linq了,并被她那优美的语法所吸引,只是现在所在的公司还在使用VS2005在.Net2.0的框架下面的开发,所以Linq也很久没有用过了,最近看部门的同事对这个有些 ...
- C# LINQ学习笔记一:走进LINQ的世界
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5832322.html,记录一下学习过程以备后续查用. LINQ 简介: 语言集成查询(LINQ)是Vi ...
- LINQ 学习笔记(1)
学习资源参考 : http://www.cnblogs.com/lifepoem/archive/2011/12/16/2288017.html 常用方法是 Where, OrderBy, Selec ...
- C# LINQ学习笔记五:LINQ to XML
本笔记摘抄自:https://www.cnblogs.com/yaozhenfa/p/CSharp_Linq_For_Xml.html,记录一下学习过程以备后续查用. 一.生成xml 1.1创建简单的 ...
- C# LINQ学习笔记四:LINQ to OBJECT之操作文件目录
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5816051.html,记录一下学习过程以备后续查用. 许多文件系统操作实质上是查询,因此非常适合使用LINQ方 ...
- C# LINQ学习笔记三:LINQ to OBJECT之操作字符串
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5814204.html,记录一下学习过程以备后续查用. 一.统计单词在字符串中出现的次数 请注意,若要执行计数, ...
- C# LINQ学习笔记二:LINQ标准查询操作概述
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5801249.html,记录一下学习过程以备后续查用. “标准查询运算符”是组成语言集成查询 (LINQ) 模式 ...
随机推荐
- vmware搭建vSAN提示磁盘不合格或者看不到磁盘的解决办法
1.如果磁盘不合格,或者在创建磁盘组的时候看不到该磁盘,一般的原因都是该磁盘有其他分区,可以使用下面的方法来解决 a.首先开启esxi主机的ssh功能 b.登陆到esxi的后台 c. ls /dev/ ...
- day1:vcp考试
Q1. An administrator wants to provide users restricted access. The users should only be able to perf ...
- actionBar_Tab导航
actionBar配合碎片使用 初始化actionBar要注意设置actionbar的导航模式 package com.qf.actionbar04_tab; import java.io.File ...
- 安装运行Rovio
https://github.com/ethz-asl/rovio下载代码,该存储库包含ROVIO(Robust Visual Inertial Odometry)框架. https://github ...
- JavaScript 中的 NaN 和 isNaN
1.NaN NaN 即 Not a Number , 不是一个数字.那么 NaN 到底是什么呢? 在 JavaScript 中,整数和浮点数都统称为 Number 类型 .除此之外,Number 类型 ...
- linux-radhat-gitlab服务搭建
1.安装gitlab的依赖项 sudo yum install -y curl policycoreutils-python openssh-server cronie 2.设置防火墙 sudo lo ...
- Linux动态共享库
Linux操作系统上面的动态共享库大致分为三类: 一.操作系统级别的共享库和基础的系统工具库 libc.so, libz.so, libpthread.so等等,这些系统库会被放在/lib和/us ...
- Window 编码 UTF-8 BOM 说明
UTF-8 不需要 BOM,尽管 Unicode 标准允许在 UTF-8 中使用 BOM.所以不含 BOM 的 UTF-8 才是标准形式,在 UTF-8 文件中放置 BOM 主要是微软的习惯(顺便提一 ...
- json.dumps错误:'utf8' codec can't decode byte解决方案-乾颐堂
一次在使用json.dumps()过程中,出现错误提示: ERROR:"UnicodeDecodeError: 'utf8' codec can't decode byte 0xe1 in ...
- [Groovy] 学习Groovy的好网站(内容全面)
https://www.tutorialspoint.com/groovy/index.htm