C# 常用排序方式------常规数据排序
** 前言**
在最近的项目中经常会对C#中的数据进行排序,对于基本数据类型,其排序方式比较简单,只需要调用内置算法即可实现,但对于
自定义数据类型
以及自定义排序规则
的情况实现起来就比较麻烦,所以在本文章中将详细介绍一下在中C#中如何对数据进行排序。
** 应用技术: LINQ; Array.Sort();**
文章目录
- [1. 使用Sort排序](#1. 使用Sort排序)
- [2. 使用LINQ语句进行排序](#2. 使用LINQ语句进行排序)
- [3. 多条件排序](#3. 多条件排序)
- [4. 总结](#4. 总结)
1. 使用Sort排序
对于系统内置数据,我们可以使用Sort
方法直接进行排序,默认是采用正序进行排序,此处提供了三种方式:
- 方式一:使用默认的
Sort()
方法直接就可以进行排序。 - 方式二:使用
Sort()
方法并添加回调函数,回调函数调用数据类型CompareTo()
方法。 - 方式三:使用
Sort()
方法并添加回调函数,回调函数进行自定义,此处采用三目运算符写了个简单的方法。
csharp
static void test_general_sort()
{
int[] data = { 89, 63, 48, 62, 75, 663, 45, 359, 42 };
// 1. 方式一
Array.Sort(data);
// 2. 方式二
Array.Sort(data, (x, y) => x.CompareTo(y));
// 3. 方式三
Array.Sort(data, (x, y) => x > y ? 1 : -1);
print_array(data);
}
如果是想进行逆序排序,最简单的方式就是将正序排列的数组进行一次反转即可,不然的话就是改变方法二以及方法三的回调函数输出,如下面代码所示。
csharp
static void test_general_sort_()
{
int[] data = { 89, 63, 48, 62, 75, 663, 45, 359, 42 };
// 1. 方式一
Array.Sort(data);
Array.Reverse(data);
// 2. 方式二
Array.Sort(data, (x, y) => y.CompareTo(x));
// 3. 方式三
Array.Sort(data, (x, y) => x > y ? -1 : 1);
print_array(data);
}
2. 使用LINQ语句进行排序
然后我们介绍一下使用LINQ语句进行排序,LINQ是一组用于C#和Visual Basic语言的扩展。它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。在此处我们可以使用两种方式实现:
- 方式一:使用原生的LINQ语句进行查询,此处主要通过自己写LINQ语句;
- 方式二:使用封装好的方法
OrderBy()
,该方法使用比较简单,可以直接调用对应大方法即可。
csharp
static void test_general_linq()
{
int[] data = { 89, 63, 48, 62, 75, 663, 45, 359, 42 };
// 1. 方式一
IEnumerable<int> query = from d in data
orderby d
select d;
// 2. 方式二
query = data.OrderBy(x => x);
print_array(query);
}
如果要项进行逆序排序,此处可以添加descending
关键字进行设定,或者直接使用OrderByDescending()
方法。
csharp
static void test_general_linq_()
{
int[] data = { 89, 63, 48, 62, 75, 663, 45, 359, 42 };
// 1. 方式一
IEnumerable<int> query = from d in data
orderby d descending
select d;
// 2. 方式二
query = data.OrderByDescending(x => x);
print_array(query);
}
3. 多条件排序
在实际使用时,我们可能会遇到多条件排序,即第一个条件相等时时,在采用第二个条件排序,如果遇到这种情况,我们处理起来可能就比较麻烦。如下面代码所示,对于一个字符串数组,我想首先按照字符串长度进行排序,如果字符串长度相等,就按照首字母进行排序。实现方式如下所示:
csharp
static void test_general_sort_more()
{
string[] words = { "the", "quick", "brown", "fox", "jumps", "and" };
Array.Sort<string>(words, (x, y) =>
{
if (x.Length > y.Length) { return 1; }
else if (x.Length == y.Length)
{
if (x.Substring(0, 1)[0] > y.Substring(0, 1)[0]) { return 1; }
else { return -1; }
}
else { return -1; }
});
print_array(words);
}
在上面这段代码中,我们主要是使用了Lambda
表达式创建了一个委托函数,在这个委托函数里,我们按照排序要求,对其进行了定义,主要是对返回值的条件进行了定义,最后排序结果输出为:
bash
Array = {the, quick, brown, fox, jumps, and}
Array = {and, fox, the, brown, jumps, quick}
不过该方式看起来实现是比较复杂的,对于大多是人来说,可能很难看懂,所以此处我们向大家展示一个比较简单的方式,就是使用LINQ语句进行多条件排序,如下面代码所示:
csharp
static void test_general_linq_more()
{
string[] words = { "the", "quick", "brown", "fox", "jumps", "and" };
// 1. 方式一
IEnumerable<string> query = from word in words
orderby word.Length, word.Substring(0, 1)
select word;
// 2. 方式二
query = words.OrderBy(x => x.Length).ThenBy(x => x.Substring(0, 1));
print_array(query);
}
使用LINQ语句进行排序看起来就比较简单了,上面依旧是展示了两种方式,对于多条件排序,如果使用自定义LINQ语句排序就只需要在上一个条件后增加次要条件即可;如果使用封装后的LINQ语句,就可以在OrderBy()
增加ThenBy()
方法添加第二个条件。如果想实现反向排序,实现方式与上文相同。
4. 总结
以上就是给大家带来的常规数据排序方法一些实现方式,希望大家在日常使用中能够用到。