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.hqwc.cn/news/316938.html

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

相关文章

众和策略股市行情分析:股票分红是按持股比例来分的吗?

股票分红立足于同股同利的准则&#xff0c;按股东的持股比例来进行股利的派发分红。持股多的股东按比例所得的分红就多&#xff0c;持股少的股东按比例所得的分红就少。 另外&#xff0c;分红详细是指的股票发行公司分配股利的行为。股利包含股息和盈利&#xff0c;股息是指的…

CCF模拟题 202312-1 仓库规划

问题描述 试题编号&#xff1a; 202312-1 试题名称&#xff1a; 仓库规划 时间限制&#xff1a; 1.0s 内存限制&#xff1a; 512.0MB 问题描述&#xff1a; 输入格式 输出格式 样例输入 4 2 0 0 -1 -1 1 2 0 -1样例输出 3 1 0 3样例解释

性能优化-OpenMP基础教程(二)

本文主要介绍OpenMP并行编程的环境变量和实战、主要对比理解嵌套并行的效果。 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09;开发基础教程 &#x1f380;CSDN主页 发狂的小花 &…

云原生学习系列之基础环境准备(虚拟机搭建)

最近由于工作需要开始学习云原生相关内容&#xff0c;为方便学习操作&#xff0c;准备在外网搭建自己的环境&#xff0c;然后进行相关的练习&#xff0c;搭建环境的第一步便是虚拟机的安装。 基础软件 这里我用到的是CentOS-7-x86_64的操作系统。 链接&#xff1a;https://pa…

Mac环境下Parallels Desktop 19的安装和使用

为了后续构建漏洞靶场和渗透测试环境&#xff0c;我们需要提前准备好几套与宿主机隔离的工作环境&#xff08;Windows、Linux等&#xff09;&#xff0c;在Mac上最常用的就是Paralles Desktop&#xff08;PD&#xff09;工具了&#xff0c;当前最新版本为19。接下来介绍如何安装…

Go后端开发 -- main函数 变量 常量 函数

Go后端开发 – main函数 & 变量 & 常量 & 函数 文章目录 Go后端开发 -- main函数 & 变量 & 常量 & 函数一、第一个main函数1.创建工程2.main函数解析 二、变量声明1.单变量声明2.多变量声明 三、常量1.常量的定义2.优雅的常量 iota 四、函数1.函数返回…

Rancher 单节点 docker 部署备份与恢复

Rancher 单节点 docker 部署备份与恢复 1. 备份集群 获取 rancher server 容器名&#xff0c;本例为 angry_aryabhata docker ps | grep rancher/rancher6a27b8634c80 rancher/rancher:v2.5.14 xxx angry_aryabhata停止容器 docker stop angry_aryabhata创建备…

终于找全了:蝴蝶效应、青蛙现象、鳄鱼法则、鲇鱼效应、羊群效应、刺猬法则、手表定律、破窗理论、二八定律、木桶理论,值得收藏

1、蝴蝶效应: 上个世纪70年代&#xff0c;美国一个名叫洛伦兹的气象学家在解释空气系统理论时说&#xff0c;亚马逊雨林一只蝴蝶翅膀偶尔振动&#xff0c;也许两周后就会引起美国得克萨斯州的一场龙卷风。   蝴蝶效应是说&#xff0c;初始条件十分微小的变化经过不断放大&…

[LitCTF 2023]Vim yyds

[LitCTF 2023]Vim yyds wp 题目页面如下&#xff1a; 搜索一番&#xff0c;没有发现任何信息。题目描述中说到了源码泄露&#xff0c;那么先进行目录扫描。 dirsearch 目录扫描 命令&#xff1a; dirsearch -u "http://node4.anna.nssctf.cn:28588/"返回结果&…

vue-vuex持久化处理

在src/utils文件夹下&#xff0c;创建storage.js文件 // 约定一个通用的键名 const INFO_KEY hm_shopping_info// 获取个人信息 export const getInfo () > {const defaultObj { token: , userId: }const result localStorage.getItem(INFO_KEY)return result ? JSON…

Vuex(vue2中的状态机)

目录 Vuex state属性 getters属性 mutations属性 actions属性 modules属性 辅助函数 Vuex 状态管理模式 维护公共状态 公共数据 使用状态机模块维护状态 A组件中分发工作&#xff08;发起异步请求)--->获取数据--->提交突变(将数据提交给突变 ) 通过突变修改状态…