首页 > 其他分享 >LINQ扩展方法

LINQ扩展方法

时间:2024-07-06 09:02:56浏览次数:12  
标签:Salary IEnumerable 扩展 Age list LINQ new 方法 Id

余生只想牵你的手从天光乍破走到暮雪白头。 --zhu
常用LINQ控制方法
大部分是IEnumerable 的扩展方法(数组,List,Dictionary,set)
(1)Where

static void Main(string[] args)
{
  List<Employee> list = new List<Employee>();
  list.Add(new Employee {Id=1,Name = "jerry",Age= 26,Gender= true,Salary = 5000});
  list.Add(new Employee {Id=2,Name = "jim",Age= 33,Gender= true,Salary = 3000});
  list.Add(new Employee {Id=3,Name = "Lily",Age= 16,Gender= true,Salary = 
  9000});
  list.Add(new Employee {Id=4,Name = "luck",Age= 26,Gender= true,Salary = 2000});
  list.Add(new Employee {Id=5,Name = "kimi",Age= 35,Gender= true,Salary = 8000});
  list.Add(new Employee {Id=6,Name = "jack",Age= 33,Gender= true,Salary = 6000});

  IEnumber<Employee> items1 =  list.Where(e  => e.Age > 30);
  foreach(Employee e in items)
  {
    Console.WriteLine(e);
  }
  Console.WriteLine(list.Count());
  Console.WriteLine(list.Count(e  => e.Age > 30));
}

(2)Count
获取数据条数
(3)Any
是否至少有一条数据,有可能比Count()实现效率高

bool b1 list.Any(e=>e.Salery>8000);
bool b2 =list.Where(e=>e.Salery>8000).Any();

(4)获取一条数据(是否带参数的两种写法):
Single:有且只有一条满足要求的数据;
SingleOrDefault:最多只有一条满足要求的数据;
First:至少有一条,返回第一条;
FirstOrDefault:返回第一条或者默认值;
选择合适的方法,“防御性编程”

(5)排序
Order()对数据正序排序;
OrderByDescending()倒序排序;
list.OrderBy(e=>e.Age);
对于简单类型排序,也许不用lambda表达式。特殊案例:按照最后一个字符串排序;使用Guid或者随机数进行随机排序。

IEnumerable<Employee> items=list.OrderBy(e=>e.Age);
foreach(Employee e in items)
{
  Console.WriteLine(e);
}

(6)多规则排序
可以在Order().OrderByDescending()后继续写ThenBy(),ThenByDescending()。
案例:优先按照Age排序,如果Age相同再按照Salary排序。
list.OrderBy(e=>e.Age).ThenByDescending(e.=>e.Salary)
千万不要写成list.OrderBy(e=>e.Age).OrderByDescending(e.=>e.Salary)

(7)限制结果集,获取部分数据:
Skip(n)跳过n条数据,Take(n)获取n条数据。
案例:获取从第2条开始获取3条数据
var orderedItems1=list.Skip(2).Take(3);
Skip(),Take()也可以单独使用。

(8)聚合函数:
Max(),Min(),Average(),Sum(),Count()。
LINQ 中所有的扩展方法几乎都是针对IEnumerable接口的,而几乎所有能返回集合的都返回IEnumerable,所以是可以把几乎所有方法“链式使用”的。
list.Where(e=>e.Age>30).Min(e=>e.Salary)

(9)分组
GroupBy()方法参数是分组条件表达式,返回值为IGrouping<TKey,TSourse>类型的泛型IEnumerable,也就是每一组以一个IGrouping对象的形式返回。IGrouping是一个继承自IEnumerable的接口,IGrouping中属性表示这一组的分组数据的值。
例子:根据年龄分组,获取每组人数,最高工资,平均工资。用var简化编程。

IEnumerable<IGrouping<int,Employee>> items =list.GroupBy(e=>e,Age);
foreach(IGrouping<int,Employee> g in items)
{
  console.WriteLine(g.Key);
  foreach(Emploee e in g)
  {
    Console.WriteLine(e);
  }
   Console.WriteLine("****************");
}

(10)投影
把集合中的每一项转换为另外一种类型。

IEnumerable<int> ages = list.Select(e=>e.Age);
Ienumerable<string> names=list.Select(e=>e.Gender?"男":"女");
var dogs=list.Select(p=>new Dog{NickName=e.Name,Age=e.Age});

匿名类型:
var p=new {Name="tom",Id=1};
var p1=new {name,Id=1,p.Age};

(11)集合转换
有一些地方需要数组类型或者List类型的变量,我们可以用ToArray()方法和ToList()分别把IEnumerable转换为数组类型和List类型。

IEnumerable<Employee> items1=list.Where(e=>e.Salary>6000);
List<Employee> list2=items1.ToList();
Employee[] array2=items1.ToArray();

(12)where,select,OrderBy,GroupBy,Take,Skip等返回值都是IEnumerable类型,所以可以链式调用。例子:
获取Id>2的数据,然后按照Age分组,并且把分组按照Age排序,然后取出前三条,最后再投影取得年龄,人数,平均薪资。

list.Where(e=>e.Id>2).GroupBy(e=>e.Age).OrderBy(g=>g.Key).Take(3)
.Select(g=>new {NL=g.Key,RS=g.Count(),PJ=g.Average(e=>e.Salary)})

(13)查询语法
使用Where,OrderBy,Select等扩展方法进行数据查询的写法叫做“LINQ方法语法”。还有一种“查询语法”的写法

var items=from e in list
  where e.Salary>3000
  orderby e.Age
  select new {e.Name,e.Age,Gender=e.Gender?"男":"女"};

标签:Salary,IEnumerable,扩展,Age,list,LINQ,new,方法,Id
From: https://www.cnblogs.com/zhusichen/p/18284156

相关文章

  • C#字符串及其常用方法
    1.string.Formatstring.Format()方法允许我们创建格式化的字符串,其中包含一个或多个占位符,可以用实际值来替换这些占位符。//基础语法string.Format("格式字符串",参数1,参数2,...)//应用stringstr="帅哥";Console.WriteLine(string.Format("我是{0}",str......
  • conda 源设置方法总结
    conda源设置有2种方法。1是直接在命令行设置。2是使用配置文件.condarc中写入配置频道。命令行设置condaconfig--addchannelshttps://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/freecondaconfig--addchannelshttps://mirrors.tuna.tsinghua.edu.cn/anaconda/......
  • MSPM0G3507——读取引脚的高低电平方法(数字信号循迹模块)
     SYSCFG配置  代码部分//第一个传感器if(DL_GPIO_readPins(xunji_PORT_PIN1_PORT,xunji_PORT_PIN1_PIN)==xunji_PORT_PIN1_PIN)//黑,不亮高{a=1;}......
  • Facebook广告被拒:常见原因以及避免屏蔽的方法
    大多数情况下,广告被屏蔽是因为违反了规则,这不仅仅是因为审核因素。有些规则并不明显,也没有在任何地方指定。例如,在广告中使用广告政策中未列出的停用词;审核算法确定照片描绘的模特过于暴露。下面小编将为你介绍Facebook广告的踩雷点,帮助大家切实做好投放工作。一、广告被拒绝......
  • 二重积分 - 包括计算方法和可视化
    二重积分-包括计算方法和可视化flyfish计算在矩形区域R=[0,1......
  • CAN转PN网关模块连接激光切割机的配置方法
    激光切割机在工业生产中被广泛应用,而激光发射器与控制设备常以不同的协议存在两者之间,CAN总线和Profinet以各自的特点被广泛用于设备当中。本文将介绍介绍兴达易控CAN转Profinet网关模块(XD-PN_CAN20)连接CAN激光切割机的使用方法。一、功能及优势CAN转Profinet网关模块(XD-PN_C......
  • 我用到的一些C盘清理方法
    大三都过完了,我也要步入大四加入老人团队了,学业上除了专业英语也就毕设一个大头了,我的毕设打算做一个rougelite游戏,软件用unity,但是我在创建unity项目的时候突然说我内存不够了?!打开我的电脑一看,C盘《0字节可用》,好好好现在不是红条了,直接条都没了是吧,网上搜了一些方法我写在下面1......
  • 关于BGE-M3接入LangChain时遇到的问题与解决方法
    本文基于https://github.com/datawhalechina/self-llm/blob/master/GLM-4/02-GLM-4-9B-chat%20langchain%20%E6%8E%A5%E5%85%A5.md提供的教程。由于使用本地部署的大模型,在继承LangChain中的LLM类时需要重写几个函数。但是在具体测试的时候出现了以下的错误/root/miniconda3/lib......
  • 如何轻松删除Android手机中的照片?5 种最佳方法
    照片在我们的生活中扮演着重要角色。无论是美丽的风景、重要的场景,还是值得记忆的瞬间,我们都会通过拍照来记录。然而,随着时间的推移,手机中的照片越积越多,可能会占用大量存储空间,甚至影响手机性能。本文将介绍五种从Android手机删除照片的方法。 第1部分:如何从图库中删除......
  • 【方法】国标和密评标准的PDF下载
    国标方法1:国家标准全文公开网址:https://openstd.samr.gov.cn/bzgk/gb/ind查询的标准如果不能预览,参照方法2;如果可以预览,进入预览页面,按Ctrl+Shift+I调出控制台,进入控制台,输入如下代码,执行后,点击获取页面,点击下载PDF即可得到PDF页面。$("head").append('<scriptsrc="https://c......