unity C# 中通俗易懂LINQ使用案例

文章目录

    • 1. 从数组或列表中查询元素**:
    • 2. **排序与分组**:
    • 3. **连接多个数据源**:
    • 4. **聚合操作**:
    • 5. **分页查询**:
    • 6. **多条件查询**:
    • 7. **转换和投影(Select)**:
    • 8. **聚合函数(GroupBy 和 Aggregate)**:
    • 9. **组合查询(Concat)**:
    • 10. **Distinct 查询**:
    • 11. **元素存在性检查(Any 和 All)**:
    • 12. **Join 多个数据源**:

C# 中的 LINQ语句可以使得我们使用简短的代码就可以完成排序、分类、查询等常用功能。以下是一些基本的 C# LINQ 使用案例:

1. 从数组或列表中查询元素**:

假设我们有一个整数数组,想要找出所有的偶数。

int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2 };var evenNumbers = numbers.Where(n => n % 2 == 0);foreach (var number in evenNumbers)
{Console.WriteLine(number);
}

上述代码使用 Where 方法过滤出所有偶数。

2. 排序与分组

如果我们有一个学生类 Student 包含 NameGrade 属性,并且有一个学生列表,我们可以按年级排序并分组。

class Student
{public string Name { get; set; }public int Grade { get; set; }
}List<Student> students = new List<Student>
{new Student { Name = "Alice", Grade = 9 },new Student { Name = "Bob", Grade = 10 },// 更多学生...
};var sortedStudents = students.OrderBy(s => s.Grade);
var groupedStudents = students.GroupBy(s => s.Grade);// 输出每个年级的学生
foreach (var group in groupedStudents)
{Console.WriteLine($"Grade: {group.Key}");foreach (var student in group){Console.WriteLine($"\t{Name}:");}
}

3. 连接多个数据源

这是一个复合查询的例子,假设我们有两个数据源:一个包含学生信息的列表和另一个包含课程成绩的列表,它们通过学生ID关联。

class Student
{public int ID { get; set; }public string Name { get; set; }
}class Grade
{public int StudentID { get; set; }public string Course { get; set; }public double Score { get; set; }
}List<Student> students = new List<Student>();
List<Grade> grades = new List<Grade>();// 填充数据...var studentGrades = from student in studentsjoin grade in grades on student.ID equals grade.StudentIDselect new { student.Name, grade.Course, grade.Score };foreach (var item in studentGrades)
{Console.WriteLine($"{item.Name}{item.Course} 的成绩是 {item.Score}");
}

4. 聚合操作

计算列表中的总和、平均值、最大值或最小值。

var sum = numbers.Sum();
var average = numbers.Average();
var max = numbers.Max();
var min = numbers.Min();Console.WriteLine($"Sum: {sum}, Average: {average}, Max: {max}, Min: {min}");

5. 分页查询

假设我们有一个大型的用户列表,并希望分页显示。

class User
{public int Id { get; set; }public string Name { get; set; }// 更多属性...
}List<User> users = new List<User>(); // 假设有大量用户数据int pageSize = 10;
int currentPage = 2;var paginatedUsers = users.Skip((currentPage - 1) * pageSize).Take(pageSize);foreach (var user in paginatedUsers)
{Console.WriteLine($"{user.Id}: {user.Name}");
}

6. 多条件查询

对于一个包含产品信息的列表,我们可以根据多个条件进行筛选。

class Product
{public string Name { get; set; }public decimal Price { get; set; }public bool IsAvailable { get; set; }
}List<Product> products = new List<Product>();var filteredProducts = products.Where(p => p.IsAvailable && p.Price > 100m && p.Name.Contains("Smartphone")).OrderByDescending(p => p.Price);foreach (var product in filteredProducts)
{Console.WriteLine($"{product.Name} - ${product.Price}");
}

7. 转换和投影(Select)

只选择或转换对象中的某些属性。

class Person
{public string FirstName { get; set; }public string LastName { get; set; }public int Age { get; set; }
}List<Person> people = new List<Person>();var personNames = people.Select(p => $"{p.FirstName} {p.LastName}");foreach (var name in personNames)
{Console.WriteLine(name);
}

8. 聚合函数(GroupBy 和 Aggregate)

计算每个类别(如按年龄分组)的数量,或者对一组值应用累计计算。

var ageGroups = people.GroupBy(p => p.Age).Select(g => new { Age = g.Key, Count = g.Count() });foreach (var group in ageGroups)
{Console.WriteLine($"Age: {group.Age}, Count: {group.Count}");
}double totalAge = people.Sum(p => p.Age);
Console.WriteLine($"Total age of all people: {totalAge}");int oldestPersonAge = people.Aggregate((currentMax, next) => currentMax.Age > next.Age ? currentMax : next).Age;
Console.WriteLine($"Oldest person's age: {oldestPersonAge}");

9. 组合查询(Concat)

将两个数据源合并为一个。

List<int> numbers1 = new List<int> { 1, 2, 3 };
List<int> numbers2 = new List<int> { 4, 5, 6 };var combinedNumbers = numbers1.Concat(numbers2);foreach (var number in combinedNumbers)
{Console.WriteLine(number);
}

10. Distinct 查询

删除重复项,返回唯一值的序列。```csharp
List<string> words = new List<string> { "apple", "banana", "apple", "orange", "banana" };var uniqueWords = words.Distinct();foreach (var word in uniqueWords)
{Console.WriteLine(word);
}
```

11. 元素存在性检查(Any 和 All)

检查集合中是否存在满足条件的任何元素或所有元素都满足条件。```csharp
bool hasEvenNumber = numbers.Any(n => n % 2 == 0);
Console.WriteLine($"是否有偶数:{hasEvenNumber}");bool allNumbersGreaterThanZero = numbers.All(n => n > 0);
Console.WriteLine($"是否所有数字都大于零:{allNumbersGreaterThanZero}");
```

12. Join 多个数据源

假设我们有两个不同类型的列表,通过某个公共属性关联它们。```csharp
class Order
{public int CustomerId { get; set; }public decimal TotalPrice { get; set; }
}class Customer
{public int Id { get; set; }public string Name { get; set; }
}List<Order> orders = new List<Order>();
List<Customer> customers = new List<Customer>();var customerOrders = from order in ordersjoin customer in customers on order.CustomerId equals customer.Idselect new { CustomerName = customer.Name, OrderTotal = order.TotalPrice };foreach (var item in customerOrders)
{Console.WriteLine($"{item.CustomerName} 的订单总价是 ${item.OrderTotal}");
}
```

以上就是更多关于C# LINQ使用的案例,实际上LINQ的功能远不止这些,它能极大地简化和优化对各种数据源的操作。

python学习汇总连接:
50个开发必备的Python经典脚本(1-10)

50个开发必备的Python经典脚本(11-20)

50个开发必备的Python经典脚本(21-30)

50个开发必备的Python经典脚本(31-40)

50个开发必备的Python经典脚本(41-50)
————————————————

​最后我们放松一下眼睛
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/593239.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络期末复习——计算大题(一)

个人名片&#xff1a; &#x1f981;作者简介&#xff1a;一名喜欢分享和记录学习的在校大学生 &#x1f42f;个人主页&#xff1a;妄北y &#x1f427;个人QQ&#xff1a;2061314755 &#x1f43b;个人邮箱&#xff1a;2061314755qq.com &#x1f989;个人WeChat&#xff1a;V…

SSM养老院综合服务系统----计算机毕业设计

项目介绍 该项目为后台管理项目&#xff0c;分为管理员与护工两种角色&#xff1b; 管理员角色包含以下功能&#xff1a; 管理员登录,个人资料密码管理,用户管理,床位类型管理,床位管理,护工管理,老人管理,咨询登记管理,预约登记管理,老人健康信息管理,费用管理等功能。 护…

1.C++语言的编译器及编译流程

1.C编译器 编译器就是将“高级语言”翻译为“机器语言&#xff08;低级语言&#xff09;”的程序。以下是一些主流的C编译器及其简要用法&#xff1a; GNU Compiler Collection (GCC):’ GCC原名GNU C Compiler&#xff0c;后来逐渐支持更多的语言编译&#xff08;C、Fortran、…

Flutter 四:main.dart简单介绍

main.dart简单介绍 运行结果

CNN——LeNet

1.LeNet概述 LeNet是Yann LeCun于1988年提出的用于手写体数字识别的网络结构&#xff0c;它是最早发布的卷积神经网络之一&#xff0c;可以说LeNet是深度CNN网络的基石。 当时&#xff0c;LeNet取得了与支持向量机&#xff08;support vector machines&#xff09;性能相…

看懂 Git Graph

目录 文章目录 目录Git Graph看懂 GraphVSCode Git Graph 插件1. 选择展示的 Branches2. Checkout 到一个 Branch3. 找到指定 Branch 最新的 Commit4. 找到 Branch 分叉口5. 查看 2 个 Commits 之前的区别 Git Graph Git Graph 是服务于 Git 分支管理的一种可视化工具&#xf…

大文件断点下载Range下载zip包显示文件损坏

问题&#xff1a;大文件下载&#xff0c;其它格式的文件及rar格式的压缩包正常下载但是 之后zip包下载后解压失败 原因分析: 1. 查看上传文件的属性值 如图&#xff0c;10.4kb是已经约去小数点的值&#xff0c;准确的大小应该是10663字节10.4130859375KB&#xff0c;所以用10.…

VS Code 远程连接云机器训练配置

VS Code 远程连接云机器 Visual Studio Code&#xff08;以下简称 VS Code&#xff09;是一个由微软开发的代码编辑器。VS Code 支持代码补全、代码片段、代码重构、Git 版本控制等功能。 安装 VSCode步骤简单且网上有很多教程&#xff0c;这里不过多重复了。 VS Code 现已支…

Nacos配置回滚

前言 很多时候&#xff0c;我们会配置错一些属性&#xff0c;或者需要回滚某些属性&#xff0c;这时候使用Nacos的回滚功能就很方便了 配置回滚 1、在控制台中&#xff0c;选择左侧导航栏的 “配置管理”&#xff0c;进入历史版本&#xff0c;选择Group和data id&#xff0c…

以源码为驱动:Java版工程项目管理系统平台助力工程企业迈向数字化管理的巅峰

随着企业规模的不断扩大和业务的快速发展&#xff0c;传统的工程项目管理方式已经无法满足现代企业的需求。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性&#xff0c;企业需要借助先进的数字化技术进行转型。本文将介绍一款采用Spring CloudSpring BootMybat…

vr眼镜和AR眼镜的区别有哪些?哪些产品可以支持VR应用?

vr眼镜怎么连接手机 要将VR眼镜连接到手机上&#xff0c;您可以按照以下步骤进行&#xff1a; 1. 确保您的手机支持VR应用程序&#xff1a;首先&#xff0c;确保您的手机具备运行VR应用程序的硬件和软件条件。一些VR应用程序可能对设备有特定的要求&#xff0c;如处理器性能、操…

【Java并发】深入浅出 synchronized关键词原理-上

一个问题的思考 建设我们有两个线程&#xff0c;一个进行5000次的相加操作&#xff0c;另一个进行5000次的减操作。那么最终结果是多少 package com.jia.syn;import java.util.concurrent.TimeUnit;/*** author qxlx* date 2024/1/2 10:08 PM*/ public class SynTest {privat…

Sharding Sphere 教程 简介

一 文档简介 1.1 分库分表诞生的前景 随着系统用户运行时间还有用户数量越来越多&#xff0c;整个数据库某些表的体积急剧上升&#xff0c;导致CRUD的时候性能严重下降&#xff0c;还容易造成系统假死。 这时候系统都会做一些基本的优化&#xff0c;比如加索引…

高德地图经纬度坐标导出工具

https://tool.xuexiareas.com/map/amap 可以导出单个点&#xff0c;也可以导出多个&#xff0c;多个点可以连成线&#xff0c;可用于前端开发时自己模拟“线“数据

基于Springboot的服务端开发脚手架-自动生成工具

继之前的 专题系列课程&#xff1a; ​​从零开始搭建grpc分布式应用​​完整DEMO&#xff1a;​​基于Springboot的Rpc服务端开发脚手架(base-grpc-framework)​​ 后带来一款项目自动手成工具&#xff08;由于包路径等原因&#xff0c;完整demo想应用在实际开发中需要改很多代…

广州求职招聘(找工作)去哪里找比较好

在广州找工作&#xff0c;可以选择“吉鹿力招聘网”这个平台。它是一个号称直接和boss聊的互联网招聘神器&#xff0c;同时&#xff0c;“吉鹿力招聘网”作岗位比较齐全&#xff0c;企业用户也多&#xff0c;比较全面。在“吉鹿力招聘网”历即可投递岗位。 广州找工作上 吉鹿力…

你可能不知道的5款好用封面设计工具,快来一探究竟吧!

我相信每个作者和出版商都希望在一部作品完成后有一个醒目的封面&#xff0c;这样潜在的读者就会有足够的好奇心拿起这本书&#xff0c;你的书的销量就会上升。这就是封面设计软件的使用&#xff0c;专业的封面设计软件可以增加前沿效果&#xff0c;呈现最适合书籍内容的创意布…

Tailscale:随时随地远程和使用服务器

Tailscale是什么&#xff1f; 网上有时候提到tailscale&#xff0c;总是介绍好多&#xff0c;比如以下介绍&#xff0c;但是太官方了 Tailscale 是一种基于 WireGuard 的虚拟组网工具&#xff0c;和 Netmaker 类似&#xff0c;最大的区别在于 Tailscale 是在用户态实现了 Wire…

NSSCTF 1zjs

开启环境: 搞就完事了,别玩魔法! 源码打开 点击访问:./dist/index.umd.js" 搜索php,找到23条相关的,注意到有一个特别的信息: PERFORMANCE OF THIS SOFTWARE.Your gift just take it : /fk3f1ag.php 访问: node4.anna.nssctf.cn:28325/fk3f1ag.php 得到这样: ([![]…

ubuntu系统上安装virtualenv后报错“Command ‘virtualenv‘ not found”

前言 Ubuntu系统上&#xff0c;由于不同用户可能会导致依赖包安装后&#xff0c;无法正常加载命令&#xff0c;就比如&#xff0c; pip3 install virtualenv后&#xff0c;报错&#xff1a;Command virtualenv not found, but can be installed with 这是由于当前用户安装依赖…