活代码LINQ——07
来源说明:https://blog.csdn.net/sha574810590/article/details/40738069
在LINQ中,数据源和查询结果实际上都是IEnumerable<T>或IQueryable<T>类型对象,所以可以通过使用普通对象的形式(调用方法、使用属性等)对数据源进行查询或使用查询结果数据。
1.IEnumerable<T>接口
IEnumerable<T>泛型接口支持在制定数据集合上进行迭代操作。它定义了一组扩展方法,用来对数据集合中的元素进行遍历、过滤、排序、搜索等操作。在LINQ中,数据源实际上是实现了接口IEnumerable<T>的类,通过select子句返回的查询结果页是一个实现了IEnumerable<T>的类。
在.NET类库中,IEnumerable<T>接口提供了大量与查询相关的方法。这些方法实际上是以扩展方法的形式定义,但是由于它的作用类型也为IEnumerable<T>接口,所以使用上和成员方法很类似。
IEnumerable<T>接口主要成员
|
成员 |
功能 |
| Aggregate | 对序列应用累加器函数,可以指定累加方法 |
| Sum |
计算序列中所有元素的和,返回值有int、long、float、double、decimal类型,并且可以指定元素到数值的映射方法 |
| Average |
计算序列中所有元素的平均值,返回值有int、long、float、double、decimal类型,并且可以指定元素到数值的映射方法 |
| Max | 计算序列中所有元素的最大值,返回值有int、long、float、double、decimal类型,并且可以指定元素到数值的映射方法 |
| Min | 计算序列中所有元素的最小值,返回值有int、long、float、double、decimal类型,并且可以指定元素到数值的映射方法 |
| All | 检查是否序列中所有元素都满足条件,可以指定条件判断方法。如果所有元素都满足条件返回True,否则返回False |
| Any | 检查序列中是否有任何一个元素满足条件,可以指定条件的判断方法。如果有一个以上(含一个)元素满足条件返回True,否则返回False |
| Contains | 检查数据系列中是否包含特定的元素,可以指定相等比较方法 |
| Count | 返回序列中满足指定条件的元素的数量,可以指定条件判断方法 |
| LongCount | 返回序列中满足指定条件的元素的长数量,可以指定条件判断方法 |
| Cast | 将IEnumerable中的元素转换为指定的数据类型 |
| DefaultIfEmpty | 返回序列中指定位置的元素。如果序列为空,则返回默认的元素值 |
| ElementAt | 返回序列中指定索引处的元素 |
| ElementAtOrDefault | 返回序列中指定索引处的元素。如果序列为空,则返回默认值 |
| First | 返回序列中满足指定条件的第一个元素,可以指定条件判断方法 |
| FirstOrDefault | 返回序列中满足指定条件的第一个元素。如果不存在则返回默认值,也可以指定条件判断方法 |
| Last | 返回序列中满足指定条件的最后一个元素,可以指定条件判断方法 |
| LastOrDefault | 返回序列中满足指定条件的最后一个元素。如果不存在则返回默认值,也可以指定条件判断方法 |
| Single | 返回序列中满足指定条件的唯一元素。如果不止一个元素满足条件会引发一场,可以指定条件判断方法 |
| SingleOrDefault | 返回序列中满足指定条件的唯一元素。如果不存在则返回默认值,如果不止一个元素满足条件会引发一场,可以指定条件判断方法 |
| Reverse | 反转序列中元素的顺序 |
| Distinct | 返回序列中不重复的元素的集合,可以指定相等比较方法 |
| Concat | 连接两个序列,直接首尾相连。返回结果可能存在重复数据 |
| Except | 获取两个元素集合的差集,可以指定相等比较方法 |
| Intersect | 获取两个元素集合的交集,可以指定相等比较方法 |
| Union | 获取两个元素集合的并集,可以指定相等比较方法 |
|
SequenceEqual |
比较两个序列是否相等,可以指定相等比较方法 |
| Where | 根据制定条件对集合中元素进行筛选,返回满足条件的元素集合 |
| Skip | 跳过序列中指定数量的元素,然后返回剩余的元素 |
| SkipWhile | 跳过序列中满足指定条件的元素,然后返回剩余的元素,可以指定条件判断方法 |
| Take | 从序列的开头返回指定数量的连续元素 |
| TakeWhile | 返回从序列开始的满足指定条件的连续元素,可以指定条件判断方法 |
| ToArray | 从IEnumerable<T>创建一个数组 |
| ToList | 从IEnumerable<T>创建一个List<T> |
从上表可以看出,IEnumerable<T>提供的方法包括数值运算(Sum、Min、Max、Average)、元素数量(Count、LongCount)、取值(First、Last、ElementAt等)、提取子集(Skip、SkipWhile、Take、TakeWhile、)集合操作(Reverse、Concat、Distinct、Except、Intersect、Union、SequenceEqual等)。这些方法提供了LINQ所需要的所有操作。
注意:
IEnuerable<T>继承自IEnumerable<T>接口,所以它也包含IEnumerable接口的所有方法,所以还包括Select()、SelectMany()、Repeat()等方法。
另外,IQuery<T>接口从IEnumerable<T>派生而来,通常也可以作为数据源使用,它的使用和IEnumerable<T>类似。
1.Aggregate(聚合)的用法:
简介:适用于集合的一个或多个聚合函数。 标准聚合函数都All, Any, Average, Count, LongCount, Max, Min,和Sum函数。
Module Module1
Sub Main()
Dim numbers1 As Integer() = {1, 2, 3, 4, 5}
Dim query1 As Integer = Aggregate num In numbers1 Into Sum(num)
Console.WriteLine("Sum = " & query1) ‘显示结果为 Sum = 15
Dim numbers2 As Decimal() = {1.9, 2, 8, 4, 5.7, 6, 7.2, 0}
Dim query2 = Aggregate num In numbers2 Into Sum()
Console.WriteLine("SumSalary = " & query2) ‘显示结果为 SumSalary = 34.8
End Sub End Module
运行结果:

2.Aggregate(聚合)数学运算:
Module Aggregate_数学运算
Sub Main()
Dim numbers As Integer() = {1, 3, 5, 6, 3, 9, 7} Dim numberTotal As Integer = Aggregate num In numbers Into Sum(num)
Dim numberMax As Integer = Aggregate num In numbers Into Max(num)
Dim numberAverage As Double = Aggregate num In numbers Into Average(num)
Dim numberCount As Integer = Aggregate num In numbers Into Count()
Dim numberMin As Integer = Aggregate num In numbers Into Min(num)
Console.WriteLine("Sum = " & numberTotal & vbCrLf & _
"Max = " & numberMax & vbCrLf & _
"Average = " & numberAverage & vbCrLf & _
"Count = " & numberCount & vbCrLf & _
"Min = " & numberMin)
End Sub
End Module
运算结果:

3.Distinct分句的用法
'将list列表的元素以集合的形式传给IEnumerable接口
Module ListCollection
Sub Main()
Dim items As New List(Of String)
items.Add("red")
items.Insert(0, "yellow")
items.Add("green")
items.Add("yellow")
Dim delChongfu = _
From element In items _
Select element _
Distinct '若有相同的值,保留一个值,删除其他的值
Display(delChongfu)
End Sub ' Main Sub Display(ByVal items As IEnumerable)
For Each item In items
Console.Write(" {0}", item)
Next
Console.WriteLine()
End Sub
End Module
运行结果(本来有两个yellow,只保留了一个yellow):

来源:https://blog.csdn.net/sha574810590/article/details/40738069
活代码LINQ——07的更多相关文章
- 活代码LINQ——09
一.代码 ' Fig. 9.7: LINQWithListCollection.vb ' LINQ to Objects using a List(Of String). Module LINQWit ...
- 活代码LINQ——06
一.模块代码 ' Fig. 9.4: LINQWithArrayOfObjects.vb ' LINQ to Objects using an array of Employee objects. M ...
- 活代码LINQ——01
序言 此系列的所有代码都是运行在Win 7 64位 + Visual Basic 2008 Express Edition的环境中 之所以学习List集合类,是因为我们先前学习的数组自身的缺陷: 1. ...
- 活代码LINQ——08
一.模块代码 ' Fig. 9.6: ListCollection.vb ' Generic List collection demonstration. Module ListCollection ...
- 活代码LINQ——05
片段代码: ' Exercise 9.3 Solution: Invoice.vb ' Invoice class. Public Class invoide ' declare variables ...
- 活代码LINQ——04
一.主模块代码: 'Fig.4.16:GradeBookTest.vb 'Create and manipulate a GradeBook object;illustrate validation ...
- 活代码LINQ——03
一.主模块代码: 'Fig.4.13:GradeBookTest.vb 'GradeBook constructor used to specify the course name at the 't ...
- 活代码LINQ——02
一.复习基础——属性与实例变量 'Fig. 4.8:GradeBookTest.vb 'Create and manipulate a GradeBook object. Module GradeBo ...
- Linq to EF 与Linq to Object 使用心得
大家都知道Linq既可以用来查询数据库对象(我这里指的是Entity FrameWork里的Model对象),也可以用来查询内存中的IEnumerable对象. 两者单独查询时都不会出现什么问题,不过 ...
随机推荐
- 第一次远程ubuntu用c写Hello Word出现的问题
2019-03-26 21:48:48 之前已经学过c语言,但是一直是在win10上用VC++6.0来写代码的,现在想尝试在linux下用c语言 其实主要目的是来学习linux 1.问题: 在ubun ...
- list set map区别及适用场景
list与Set.Map区别及适用场景 1.List,Set都是继承自Collection接口,Map则不是 2.List特点:元素有放入顺序,元素可重复 ,Set特点:元素无放入顺序,元素不可重 ...
- 【做题】ZJOI2017仙人掌——组合计数
原文链接 https://www.cnblogs.com/cly-none/p/ZJOI2017cactus.html 给出一个\(n\)个点\(m\)条边的无向连通图,求有多少种加边方案,使得加完后 ...
- 在线预览-Java 使用 Print2Flash 实现Office文档在线阅读
近期项目上遇到一个需求是用户上传的文档进行在线浏览,之前有过一篇使用 OpenOffice 将 word 转换成 html 页面进行展示的.现在介绍一个新的工具那就是 Print2Flash . ...
- Visual Studio 2017/2019 企业版 Enterprise 激活码
VS2017 Enterprise: NJVYC-BMHX2-G77MM-4XJMR-6Q8QF VS2017 Professional: KBJFW-NXHK6-W4WJM-CRMQB-G3CDH ...
- 承接微信小程序外包 H5外包就找北京动点软件开发团队
承接小程序外包 微信小程序外包 H5外包 就找北京动点软件 长年承接微信小程序.微信公众号开发 全职的H5开发团队,开发过几十款微信小程序公众号案例 欢迎来电咨询,索取案例! QQ:372900288 ...
- vue 组件之间相互传值 父传子 子传父
1.父传子 把要传入的值放到父标签里 子组件使用props接收 父写法 子写法 2.子传父 子组件: childrenOnclick() { // 发布自定义事件 this.$emit(" ...
- @staticmethod和@classmethod
一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法. 而使用@staticmethod或@classmethod,就可以不需要实例化,直接类名.方法名()来调用. 这有利于组织代码,把某些应 ...
- python小技巧---打印出不同颜色的输出
在调试代码时打印常常一种颜色,找个东西真的是很难,在一次听金角大王的视频中听到了个方法,也是喀什使用了,本来不打算做记录了,可是稍微有几天不用,还得翻之前的代码,找着也是听麻烦的,现在在这里做个记录 ...
- ERROR:scala:Error:Object scala.runtime in compiler mirror not found
我的项目是sbt项目,今天早晨的时候还好好的,结果中午吃了个饭回来就特么的编译就报错了,真是闹心 报错截图: 解决方案: 删除idea的缓存文件 然后重新启动idea,重新下载jia包,在进行编译,就 ...