活代码LINQ——06
一、模块代码
' Fig. 9.4: LINQWithArrayOfObjects.vb
' LINQ to Objects using an array of Employee objects.
Module LINQWithArrayOfObjects
Sub Main()
' initialize array of employees
Dim employees As Employee() = { _
New Employee("Jason", "Red", 5000D), _
New Employee("Ashley", "Green", 7600D), _
New Employee("Matthew", "Indigo", 3587.5D), _
New Employee("James", "Indigo", 4700.77D), _
New Employee("Luke", "Indigo", 6200D), _
New Employee("Jason", "Blue", 3200D), _
New Employee("Wendy", "Brown", 4236.4D)} ' end initializer list Display(employees, "Original array") ' display all employees ' filter a range of salaries using AndAlso in a LINQ query
Dim between4K6K = _
From e In employees _
Where e.MonthlySalary >= 4000D AndAlso e.MonthlySalary <= 6000D _
Select e ' display employees making between 4000 and 6000 per month
Display(between4K6K, String.Format( _
"Employees earning in the range {0:C}-{1:C} per month", _
4000, 6000)) ' order the employees by last name, then first name with LINQ
Dim nameSorted = _
From e In employees _
Order By e.LastName, e.FirstName _
Select e Console.WriteLine("First employee when sorted by name:") ' header ' attempt to display the first result of the above LINQ query
If nameSorted.Count() = 0 Then
Console.WriteLine("not found" & vbNewLine)
Else
Console.WriteLine(nameSorted.First().ToString() & vbNewLine)
End If ' use LINQ's Distinct clause to select unique last names
Dim lastNames = _
From e In employees _
Select e.LastName _
Distinct ' display unique last names
Display(lastNames, "Unique employee last names") ' use LINQ to select first and last names
Dim names = _
From e In employees _
Select e.FirstName, Last = e.LastName Display(names, "Names only") ' display full names
End Sub ' Main ' display a sequence of any type, each on a separate line
Sub Display(Of T)(ByVal results As IEnumerable(Of T), ByVal header As String) Console.WriteLine("{0}:", header) ' display header ' display each element, separated by spaces
For Each element As T In results
Console.WriteLine(element)
Next Console.WriteLine() ' add end of line
End Sub ' Display End Module ' LINQWithArrayOfObjects ' **************************************************************************
' * (C) Copyright 1992-2009 by Deitel & Associates, Inc. and *
' * Pearson Education, Inc. All Rights Reserved. *
' * *
' * DISCLAIMER: The authors and publisher of this book have used their *
' * best efforts in preparing the book. These efforts include the *
' * development, research, and testing of the theories and programs *
' * to determine their effectiveness. The authors and publisher make *
' * no warranty of any kind, expressed or implied, with regard to these *
' * programs or to the documentation contained in these books. The authors *
' * and publisher shall not be liable in any event for incidental or *
' * consequential damages in connection with, or arising out of, the *
' * furnishing, performance, or use of these programs. *
' **************************************************************************
二、类代码
' Fig. 9.3: Employee.vb
' Employee class with FirstName, LastName and MonthlySalary properties.
Public Class Employee
Private firstNameValue As String ' first name of employee
Private lastNameValue As String ' last name of employee
Private monthlySalaryValue As Decimal ' monthly salary of employee ' constructor initializes first name, last name and monthly salary
Public Sub New(ByVal first As String, ByVal last As String, ByVal salary As Decimal)
FirstName = first
LastName = last
MonthlySalary = salary
End Sub ' New ' property that gets and sets the employee's first name
Public Property FirstName() As String
Get
Return firstNameValue
End Get Set(ByVal value As String)
firstNameValue = value
End Set
End Property ' FirstName ' property that gets and sets the employee's last name
Public Property LastName() As String
Get
Return lastNameValue
End Get Set(ByVal value As String)
lastNameValue = value
End Set
End Property ' LastName ' property that gets and sets the employee's monthly salary
Public Property MonthlySalary() As Decimal
Get
Return monthlySalaryValue
End Get Set(ByVal value As Decimal)
If value >= 0 Then ' if salary is non-negative(非负)
monthlySalaryValue = value
End If
End Set
End Property ' MonthlySalary ' return a String containing the employee's information
' left justify each field, and give large enough spaces so all the columns line up.
Public Overrides Function ToString() As String
Return String.Format("{0,-10} {1,-10} {2,10:C}", FirstName, LastName, MonthlySalary)
End Function ' ToString
End Class ' Employee ' **************************************************************************
' * (C) Copyright 1992-2009 by Deitel & Associates, Inc. and *
' * Pearson Education, Inc. All Rights Reserved. *
' * *
' * DISCLAIMER: The authors and publisher of this book have used their *
' * best efforts in preparing the book. These efforts include the *
' * development, research, and testing of the theories and programs *
' * to determine their effectiveness. The authors and publisher make *
' * no warranty of any kind, expressed or implied, with regard to these *
' * programs or to the documentation contained in these books. The authors *
' * and publisher shall not be liable in any event for incidental or *
' * consequential damages in connection with, or arising out of, the *
' * furnishing, performance, or use of these programs. *
' **************************************************************************
三、运行结果

来源:Visual Basic 2008 how to program
活代码LINQ——06的更多相关文章
- 活代码LINQ——09
一.代码 ' Fig. 9.7: LINQWithListCollection.vb ' LINQ to Objects using a List(Of String). Module LINQWit ...
- 活代码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——07
来源说明:https://blog.csdn.net/sha574810590/article/details/40738069 在LINQ中,数据源和查询结果实际上都是IEnumerable< ...
- 活代码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对象. 两者单独查询时都不会出现什么问题,不过 ...
随机推荐
- PowerShell自定义函数定义及调用
PowerShell是一种命令集,也有自己的语法定义及函数.本文主要介绍如何自定义powershell函数及如何调用,当初在写PowerShell自定义函数的时候查阅了很多资料都没找到如何调用自定义函 ...
- thinkphp3.2升级至thinkphp5.0.24
view文件 修改文件名 把tp3.2.3\app\module\view文件夹下所有文件夹拷贝至tp5\app\module\view 打开cmd命令窗口,cd至view文件夹下,执行dir /b ...
- 使用ODP.NET连接Oracle数据库
项目需要和第三方进行对接,奇葩的是地方没给提供接口,却提供了一个Oracle的视图 所以有了C#访问Oracle数据库的需求 1.打开nuget,安装驱动 https://www.nuget.org/ ...
- WEB API 系列(二) Filter的使用以及执行顺序
在WEB Api中,引入了面向切面编程(AOP)的思想,在某些特定的位置可以插入特定的Filter进行过程拦截处理.引入了这一机制可以更好地践行DRY(Don’t Repeat Yourself)思想 ...
- windows安装并配置 nginx
1,windows安装并配置 nginx 到nginx官网上下载相应的安装包,http://nginx.org/en/download.html: 下载并压缩放到自己目录下面,不要有中文目录 进入cm ...
- react项目中实现元素的拖动和缩放实例
在react项目中实现此功能可借助 react-rnd 库,文档地址:https://github.com/bokuweb/react-rnd#Screenshot .下面是实例运用: import ...
- 在Python中使用SMTP发送电子邮件
Python中有内置的smtplib模块,完成一封邮件的发送,需要做很多准备工作.第三方的py_smtp这个包也是基于smtplib的,在Python中使用py_smtp发送电子邮件非常方便,只要填写 ...
- 搭建日志收集系统时使用客户端连接etcd遇到的问题
问题: 在做日志收集系统时使用到etcd,其中server端在linux上,首先安装第三方包(windows)(安装过程可能会有问题,我遇到的是连接谷歌官网请求超时,如果已经出现下面的两个文件夹并且文 ...
- python-获取URL中的json数据
数据源为某系统提供的URL,打开是json文件,python代码获取如下: URL替换成自己的即可. import urllib.request def get_record(url): resp = ...
- spring boot2.0(一 ) 基础环境搭建
1.基础配置 开发环境:window jdk版本:1.8(spring boot2.0最低要求1.8) 开发工具:eclipse 构建方式:maven3 2.POM配置文件 <project x ...