C# LINQ
一、前言
学习心得:C# 入门经典第8版书中的第22章《LINQ》
二、LINQ to XML
我们可以通过LINQ to XML来创造xml文件 如下示例,我们用LINQ to XML来创造。
<Books><CSharp Time="2019"><book>C# 入门经典</book><book>C# 高级编程</book><book>C# 深入解析</book><book>WPF 编程宝典</book></CSharp><Java></Java>
</Books>
第一步引用命名空间
using System;
using System.Xml.Linq;
第二步 示例代码(两种写法)
static void Main(string[] args){XDocument doc = new XDocument(new XElement("Books", new XElement("Charp", new XAttribute("Time", 2019),new XElement(new XElement("book", "C# 入门编程")),new XElement(new XElement("book", "C# 高级编程")),new XElement(new XElement("book", "深入解析")),new XElement(new XElement("book", "编程宝典"))),new XElement(new XElement("Java", " "))));Console.WriteLine(doc);Console.WriteLine("------分割线--------");XDocument doc2 = new XDocument(new XElement("Books",new XElement("CSharp",new XAttribute("Time", 2019),new[] { new XElement("Book", "C# 入门编程"),new XElement("Book", "C# 高级编程"),new XElement("Book", "深入解析"),new XElement("Book", "编程宝典") }),new XElement("Java")));Console.WriteLine(doc2);Console.ReadLine();}
执行效果:

三、LINQ查询语法
LINQ查询语法可以帮助我们快速的查询我们想要的数据,对集合数组都管用。
第一步引用:
using System;
using System.Linq;
第二步(示例代码)
string[] chineseStrings = {
"你好", "世界", "学习", "编程", "科技",
"创新", "发展", "梦想", "努力", "成就",
"希望", "未来", "探索", "挑战", "实现"};var L = from n in chineseStrings where n.Contains("习") select n;foreach (var l in L) { Console.WriteLine(l); }Console.ReadLine();
示例解释:LINQ 查询语法来查找
chineseStrings数组中包含特定字符("习")的成员,并将结果存储在变量L中。这里的from关键字用于指定集合中的元素,where关键字用于筛选满足特定条件的元素,select则用于选择要返回的内容。
四、LINQ方法语法
上述代码我们可以使用扩展方法来实现同样效果。使用Where<T> 方法
举个例子:
string[] chineseStrings = {
"你好", "世界", "学习", "编程", "科技",
"创新", "发展", "梦想", "努力", "成就",
"希望", "未来", "探索", "挑战", "实现"};//var L = from n in chineseStrings where n.Contains("习") select n;var L= chineseStrings.Where(n => n.Contains("习"));foreach (var l in L) { Console.WriteLine(l); }Console.ReadLine();
示例解释:通过chineseStrings“.”就能看见很多可以使用的扩展方法。
五、LINQ排序查询结果
orderby 子句 orderby默认排序是A-Z 但如果加入了descending 关键字则代表相反
string[] chineseStrings = {
"啊", "吧", "从", "的", "额",
"发", "就", "和", "就",
"看", "了", "吗", "你", "哦"};var L = from n in chineseStrings orderby n descending select n;foreach (var l in L) { Console.WriteLine(l); }Console.ReadLine();
当前示例:对数组进行降序排序
输出效果:哦--你--吗--了--看--就--就--和--发--额--的--从--吧--啊--。
当然您可以自定义升序排序(默认不写关键字就是升序)
string[] chineseStrings = {
"啊", "吧啊", "从啊啊", "的啊啊啊", "额啊啊啊啊",
"发啊啊啊啊啊"};var L = from n in chineseStrings orderby n.Length select n;foreach (var l in L) { Console.WriteLine(l); }Console.ReadLine();
执行效果:

六、聚合运算符
聚合函数是指用于对一组数据执行计算,并返回单个结果的函数。这些函数通常用于对数据集合进行汇总、计数、平均值、最大值、最小值等操作。LINQ(Language Integrated Query)是 C# 中处理集合的强大工具之一,它提供了一系列的聚合函数可以应用在查询中。
using System;
using System.Linq;
namespace My
{class Program{static void Main(string[] args){int[] fiftyElementArray = new int[50] {1, 2, 3, 4, 5, 6, 7, 8, 9, 10,11, 12, 13, 14, 15, 16, 17, 18, 19, 20,21, 22, 23, 24, 25, 26, 27, 28, 29, 30,31, 32, 33, 34, 35, 36, 37, 38, 39, 40,41, 42, 43, 44, 45, 46, 47, 48, 49, 50
};Console.WriteLine($"数组元素个数{fiftyElementArray.Count()}");Console.WriteLine($"平均值{fiftyElementArray.Average()}");Console.WriteLine($"最小值{fiftyElementArray.Min()}");Console.WriteLine($"最大值{fiftyElementArray.Max()}");Console.WriteLine($"总和{fiftyElementArray.Sum()}");Console.ReadLine();}}
}
示例解释:
创建了一个包含 1 到 50 的整数数组,并使用 LINQ 的聚合函数计算了各种统计信息。当你运行这段代码时,它会输出数组的元素个数、平均值、最小值、最大值和总和。
七、单值选择查询
单值查询顾名思义就是返回结果不返回重复的值。
举个例子:
using System;
using System.Linq;
namespace My
{class Program{static void Main(){Student[] students = {new Student { ClassID = 10, Name = "张三" },new Student { ClassID = 10, Name = "李四" },new Student { ClassID = 11, Name = "王五" },new Student { ClassID = 11, Name = "赵六" },new Student { ClassID = 12, Name = "钱七" }};var student = (from m in students select m.ClassID).Distinct();foreach (var item in student){Console.WriteLine(item);}Console.ReadLine();}class Student{public string Name { get; set; }public int ClassID { get; set; }}}
}
示例解释:
使用 LINQ 查询语法从学生数组中选择每个学生的
ClassID属性,并使用Distinct()方法获取不重复的ClassID值,然后在控制台输出这些值。Distinct()方法是 LINQ 提供的一个方法,用于在序列中筛选出不重复的元素,即返回序列中唯一的元素。当然您也可以使用扩展方法Select 。举个例子:var student = students.Select(m=> m.ClassID).Distinct();
八、多级排序
多级排序指的是按照多个条件进行排序。通过LINQ查询表达式和orderby关键字可以轻松实现多级排序
举个例子:
using System;
using System.Collections.Generic;
using System.Linq;
namespace My
{class Program{static void Main(){List<Person> people = new List<Person>{new Person("Alice", 25),new Person("Bob", 30),new Person("Charlie", 35),new Person("David", 40),new Person("Eve", 45)};//按年龄排序后按姓名长度降序排序var LL= from o in people orderby o.Age orderby o.Name.Length descending select o;foreach(Person o in LL){Console.WriteLine(o.Name);}Console.ReadLine();}}class Person{public string Name { get; set; }public int Age { get; set; }public Person(string name, int age){Name = name;Age = age;}}
}
示例解释:
使用LINQ进行多级排序的示例。我创建了一个
List<Person>对象,并使用LINQ进行排序操作。首先按照年龄升序排序,然后在年龄相同时按照姓名长度降序排序。最后,使用循环遍历排序后的结果,并输出每个人的姓名。
九、分组查询
using System.Collections.Generic;
using System.Linq;
namespace My
{class Program{static void Main(){List<Student> students = new List<Student>{new Student { Name = "Alice", Age = 18 },new Student { Name = "Bob", Age = 20 },new Student { Name = "Charlie", Age = 18 },new Student { Name = "David", Age = 19 },new Student { Name = "Eve", Age = 20 },new Student { Name = "Eve", Age = 40 }};//按照名称分组// var temp = from student in students group student by student.Name;//按照年龄对学生进行分组,并按照分组后的平均年龄进行排序。var temp2 = from student in students group student by student.Age into AGe select new { AvgAge = AGe.Average(n => n.Age), AGe.Key };var temp3 = from student in temp2 orderby student.AvgAge select student;}}class Student{public string Name { get; set; }public int Age { get; set; }}
}
示例解释:
当前代码 temp2 这段赋值代码的意思是,LINQ对students数组进行操作,group student 是对当前对象进行分组操作 by student.Age 对当前student.Age 的值来进行分组 into AGe 是返回一个新的结果集,然后对这个新的结果集 创建了一个匿名对象new { AvgAge = AGe.Average(n => n.Age), AGe.Key };我们之前的写法都是返回当前的结果集,但我们这里创建了一个匿名对象 对象中有两个值 一个值是计算当前结果集的平均值n => n.Age是值具体计算的平均值成员,然后赋值给匿名类型AvgAge ,这个匿名对象的第一个值,第二个值是当前的键,也就是可以理解为分组的的组名,最后返回给Temp2。temp3 则是对temp2的结果中的平均值进行一个升序排序。
数据最后效果:

十、Join查询
可以用一个查询将两个集合当中的相同数据 用关键字进行连接。
举个例子:
using System;
using System.Collections.Generic;
using System.Linq;class Person
{public string Name { get; set; }public int Age { get; set; }
}class Person2
{public string Name { get; set; }public int Age { get; set; }
}class Program
{static void Main(string[] args){List<Person> people = new List<Person>{new Person { Name = "张三", Age = 30 },new Person { Name = "李四", Age = 25 },new Person { Name = "老六", Age = 35 }};List<Person2> people2 = new List<Person2>{new Person2 { Name = "张三三", Age = 30 },new Person2 { Name = "李四四", Age = 25 },new Person2 { Name = "老六六", Age = 35 }};var Temp = from p in people join o in people2 on p.Age equals o.Age select new { BigName = p.Name, SmallName = o.Name, p.Age }; foreach (var result in Temp){Console.WriteLine(result);}Console.ReadLine();}
}
示例解释:
使用LINQ查询语法进行连接操作,并选择一些属性进行输出。
var Temp = from p in people join o in people2 on p.Age equals o.Age select new { BigName = p.Name, SmallName = o.Name, p.Age };在
people和pets这两个对象列表之间,通过比较Person类的Age属性和Pet类的Age属性,找到相等的项,并将Person类的Name属性、Pet类的Name属性以及Person类的Age属性作为结果进行输出。
执行效果:

相关文章:
C# LINQ
一、前言 学习心得:C# 入门经典第8版书中的第22章《LINQ》 二、LINQ to XML 我们可以通过LINQ to XML来创造xml文件 如下示例,我们用LINQ to XML来创造。 <Books><CSharp Time"2019"><book>C# 入门经典</book><…...
云原生机器学习平台cube-studio开源项目及代码简要介绍
1. cube-studio介绍 云原生机器学习平台cube-studio介绍:https://juejin.cn/column/7084516480871563272 cube-studio是开源的云原生机器学习平台,目前包含特征平台,支持在/离线特征;数据源管理,支持结构数据和媒体标…...
大小端存储是什么鬼?
以下内容为本人的著作,如需要转载,请声明原文链接 微信公众号「ENG八戒」https://mp.weixin.qq.com/s/htYGddzO2xPl9kDN4lANpQ 大小端存储的划分是为了解决长度大于一个字节的数据类型内容在存储地址上以不同顺序分布的问题。 比如16位的short整形&…...
WEB:探索开源PDF.js技术应用
1、简述 PDF.js 是一个由 Mozilla 开发的开源 JavaScript 库,用于在浏览器中渲染 PDF 文档。它的目标是提供一个纯粹的前端解决方案,摆脱了依赖插件或外部程序的束缚,使得在任何支持 JavaScript 的浏览器中都可以轻松地显示 PDF 文档。 2、…...
数据分析之词云图绘制
试验任务概述:如下为所给CSDN博客信息表,分别汇总了ai, algo, big-data, blockchain, hardware, math, miniprog等7个标签的博客。对CSDN不同领域标签类别的博客内容进行词频统计,绘制词频统计图,并根据词频统计的结果绘制词云图。…...
【赠书第13期】边缘计算系统设计与实践
文章目录 前言 1 硬件架构设计 2 软件框架设计 3 网络结构设计 4 安全性、可扩展性和性能优化 5 推荐图书 6 粉丝福利 前言 边缘计算是一种新兴的计算模式,它将计算资源推向网络边缘,以更好地满足实时性、低延迟和大规模设备连接的需求。边缘计算…...
数据库01_增删改查
1、什么是数据?什么是数据库? 数据:描述事物的符号记录称为数据。数据是数据库中存储的基本对象。数据库:存放数据的仓库,数据库中可以保存文本型数据、二进制数据、多媒体数据等数据 2、数据库的发展 第一阶段&…...
MySQL——进阶篇
二、进阶篇🚩 1. 存储引擎🍆 1.1 MSQL体系结构 连接层: 连接处理,连接认证,每个客户端的权限 服务层: 绝大部分核心功能,可跨存储引擎 可插拔存储引擎: 需要的时候可以添加或拔掉…...
Python 网络编程之搭建简易服务器和客户端
用Python搭建简易的CS架构并通信 文章目录 用Python搭建简易的CS架构并通信前言一、基本结构二、代码编写1.服务器端2.客户端 三、效果展示总结 前言 本文主要是用Python写一个CS架构的东西,包括服务器和客户端。程序运行后在客户端输入消息,服务器端会…...
往年面试精选题目(前50道)
常用的集合和区别,list和set区别 Map:key-value键值对,常见的有:HashMap、Hashtable、ConcurrentHashMap以及TreeMap等。Map不能包含重复的key,但是可以包含相同的value。 Set:不包含重复元素的集合&#…...
解决服务器Tab键不能补全问题
编辑~/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-keyboard-shortcuts.xml 命令:vim ~/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-keyboard-shortcuts.xml替换:<property name“<Super>Tab” type“string” value“switch_window…...
人工智能 机器学习 深度学习:概念,关系,及区别说明
如果过去几年,您读过科技主题的文章,您可能会遇到一些新词汇,如人工智能(Artificial Intelligence)、机器学习(Machine Learning)和深度学习(Deep Learning)等。这三个词…...
数据库——LAMP的搭建及MySQL基操
1.实验内容及原理 1. 在 Windows 系统中安装 VMWare 虚拟机,在 VMWare 中安装 Ubuntu 系统,并在 Ubuntu 中搭建 LAMP 实验环境。 2. 使用 MySQL 进行一些基本操作: (1)登录 MySQL,在 MySQL 中创建用户,并对…...
抗原设计与兔单B细胞技术的结合-卡梅德生物
随着生物医学研究的不断深入,抗体疗法作为治疗疾病的有力工具逐渐成为研究的焦点。而兔单B细胞技术作为抗体研究的创新方法,其与抗原设计的有机结合为获取定制抗体打开了崭新的创新之路。本文将深入探讨抗原设计与兔单B细胞技术相互融合的原理、优势&…...
在uniapp中使用背景渐变色与背景图不生效问题
list上有文字详情以及背景图,从背景可以看出是渐变色和 背景图片的结合。 因为使用到渐变色,所以要结合 background-blend-mode 属性来实现与背景图片叠加显示,否则只通过 background: linear-gradient(); background-image: url(); 设置不会…...
Java中XML的解析
1.采用第三方开元工具dom4j完成 使用步骤 1.导包dom4j的jar包 2.add as lib.... 3.创建核心对象, 读取xml得到Document对象 SAXReader sr new SAXReader(); Document doc sr.read(String path); 4.根据Document获取根元素对象 Element root doc.getRootElement(); …...
React快速入门之交互性
响应事件 创建事件处理函数 处理函数名常以handle事件名命名 function handlePlayClick() {alert(Playing);}传递事件处理函数 函数名、匿名两种方式! function PlayButton() {function handlePlayClick() {alert(Playing);}return (<Button handleClick{handl…...
浅谈WPF之ToolTip工具提示
在日常应用中,当鼠标放置在某些控件上时,都会有相应的信息提示,从软件易用性上来说,这是一个非常友好的功能设计。那在WPF中,如何进行控件信息提示呢?这就是本文需要介绍的ToolTip【工具提示】内容…...
Android Studio 如何隐藏默认标题栏
目录 前言 一、修改清单文件 二、修改代码 三、更多资源 前言 在 Android 应用中,通常会有一个默认的标题栏,用于显示应用的名称和一些操作按钮。但是,在某些情况下,我们可能需要隐藏默认的标题栏,例如自定义标题栏…...
对于c++的总结与思考
笔者觉得好用的学习方法:模板法 1.采用原因:由于刚从c语言面向过程的学习中解脱出来,立即把思路从面向过程转到面向对象肯定不现实,加之全新的复杂语法与操作,着实给新手学习这门语言带来了不小的困难。所以ÿ…...
Halcon读取条形码和二维码
读取条形码1创建条形码句柄create_bar_code_model(: : GenOaramName,GenParamValue: BarCodeHandle)2设置条形码参数GenParamName 设置的参数element_size_min 条形码最小单位,黑条之间的最小间距barcode_width_min条形码的最小宽度persistence 设置条形码的查找精度…...
炸锅!中科院分区永久停更,新锐分区接棒,科研圈要变天?
最近科研圈最大的瓜,莫过于中科院期刊分区的“换马甲”事件——运行22年的官方中科院分区正式谢幕,原团队转身推出“新锐期刊分区”,一石激起千层浪,不同立场的声音吵翻了论坛。今天就来梳理下整个事件的来龙去脉,拆解…...
YOLOv9镜像实测:无需配置环境,快速实现目标检测全流程
YOLOv9镜像实测:无需配置环境,快速实现目标检测全流程 1. 开箱即用的YOLOv9体验 对于目标检测开发者来说,最头疼的往往不是算法本身,而是环境配置这个"拦路虎"。不同版本的CUDA、PyTorch、Python之间的兼容性问题&…...
OpCore Simplify:革新黑苹果配置流程——从繁琐到智能的EFI构建方案
OpCore Simplify:革新黑苹果配置流程——从繁琐到智能的EFI构建方案 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify OpCore Simplify是一款…...
Qwen3-VL-WEBUI效果实测:对比其他模型,看看优势在哪里
Qwen3-VL-WEBUI效果实测:对比其他模型,看看优势在哪里 1. 引言:当AI不仅能“看”,还能“做” 想象一下,你给AI看一张软件界面的截图,它不仅能告诉你界面上有什么,还能一步步指导你如何操作&am…...
RMBG-2.0隐私安全优势解析:纯本地推理杜绝图片上传与数据泄露风险
RMBG-2.0隐私安全优势解析:纯本地推理杜绝图片上传与数据泄露风险 在数字时代,图片处理已经成为日常工作和创作的重要组成部分,但随之而来的隐私安全问题也日益凸显。许多在线抠图工具需要用户上传图片到云端服务器进行处理,这不…...
Windows主题自由革命:SecureUxTheme安全启动兼容的内存补丁终极指南
Windows主题自由革命:SecureUxTheme安全启动兼容的内存补丁终极指南 【免费下载链接】SecureUxTheme 🎨 A secure boot compatible in-memory UxTheme patcher 项目地址: https://gitcode.com/gh_mirrors/se/SecureUxTheme 厌倦了Windows千篇一律…...
终极Bash Infinity代码审查指南:确保Bash框架代码质量的完整检查清单
终极Bash Infinity代码审查指南:确保Bash框架代码质量的完整检查清单 【免费下载链接】bash-oo-framework Bash Infinity is a modern standard library / framework / boilerplate for Bash 项目地址: https://gitcode.com/gh_mirrors/ba/bash-oo-framework …...
如何通过Odoo合同自动化与电子签名实现企业文档管理数字化转型
如何通过Odoo合同自动化与电子签名实现企业文档管理数字化转型 【免费下载链接】odoo Odoo. Open Source Apps To Grow Your Business. 项目地址: https://gitcode.com/GitHub_Trending/od/odoo 企业在合同管理过程中常面临效率低下、合规风险高、协作成本大等挑战。传统…...
Carsim Tiretester保姆级教程:从零生成轮胎特性曲线(附完整Excel数据导入流程)
Carsim Tiretester保姆级教程:从零生成轮胎特性曲线(附完整Excel数据导入流程) 刚接触车辆动力学仿真的工程师或学生,常常会被轮胎特性曲线的生成过程困扰。轮胎作为车辆与地面唯一的接触点,其力学特性直接影响整车的操…...
