Lamda表达式之 GroupBy 分组 、OrderByDescending排序

本文介绍了一种使用Lamda表达式进行数据分组与排序的方法。通过对获取的数据集进行处理,实现了按发布源分组并按计数降序排列的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

表结构如下:



Lamda表达式:

            List<News> model = NewsService.GetNewsAllList(null, whereCriteria, null);//获得数据
            if (model != null)//数据不为空时,分组并排序
            {
                var ls = model.GroupBy(a => a.PublishDw).Select(g => (new
                {
                    name = g.Key,
                    count = g.Count()
                })).OrderByDescending(c => c.count);
                
                Repeater1.DataSource = ls;
                Repeater1.DataBind();
            }

结果:


### Java 8 Lambda 表达式对集合进行排序的示例 在 Java 8 中,Lambda 表达式与 Stream API 的结合为集合的排序提供了简洁且功能强大的方式。以下是一些常见的示例,展示如何使用 Lambda 表达式对集合进行排序。 #### 1. 使用 `Stream.sorted()` 对集合进行自然排序 `Stream.sorted()` 方法可以对流中的元素进行自然排序,适用于实现了 `Comparable` 接口的对象。 ```java import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class NaturalOrderSortExample { public static void main(String[] args) { List<String> words = Arrays.asList("banana", "apple", "orange"); // 自然排序 List<String> sortedWords = words.stream() .sorted() .collect(Collectors.toList()); System.out.println(sortedWords); // 输出: [apple, banana, orange] } } ``` 上述代码展示了如何通过 `Stream.sorted()` 方法对字符串列表进行自然排序[^1]。 #### 2. 使用自定义比较器进行排序 当需要根据特定规则对集合进行排序时,可以传递一个 `Comparator` 给 `sorted()` 方法。 ```java import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class CustomComparatorSortExample { public static void main(String[] args) { List<String> words = Arrays.asList("banana", "apple", "orange"); // 按字符串长度排序 List<String> sortedByLength = words.stream() .sorted((s1, s2) -> Integer.compare(s1.length(), s2.length())) .collect(Collectors.toList()); System.out.println(sortedByLength); // 输出: [apple, banana, orange] } } ``` 在此示例中,Lambda 表达式 `(s1, s2) -> Integer.compare(s1.length(), s2.length())` 定义了一个按字符串长度排序的规则[^3]。 #### 3. 使用方法引用简化排序 如果排序逻辑已经存在于某个方法中,可以使用方法引用来替代 Lambda 表达式。 ```java import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class MethodReferenceSortExample { public static void main(String[] args) { List<String> words = Arrays.asList("banana", "apple", "orange"); // 使用方法引用按字符串长度排序 List<String> sortedByLength = words.stream() .sorted(Comparator.comparingInt(String::length)) .collect(Collectors.toList()); System.out.println(sortedByLength); // 输出: [apple, banana, orange] } } ``` 此代码片段展示了如何通过方法引用 `String::length` 来实现按字符串长度排序的功能[^1]。 #### 4. 对复杂对象集合进行排序 对于包含复杂对象的集合,可以通过对象的属性进行排序。 ```java import java.util.*; import java.util.stream.Collectors; class Person { String name; int age; public Person(String name, int age) { this.name = name; this.age = age; } @Override public String toString() { return name + " (" + age + ")"; } } public class ComplexObjectSortExample { public static void main(String[] args) { List<Person> people = Arrays.asList( new Person("Alice", 30), new Person("Bob", 25), new Person("Charlie", 35) ); // 按年龄升序排序 List<Person> sortedByAge = people.stream() .sorted(Comparator.comparingInt(person -> person.age)) .collect(Collectors.toList()); System.out.println(sortedByAge); // 输出: [Bob (25), Alice (30), Charlie (35)] } } ``` 上述代码展示了如何对包含 `Person` 对象的列表按年龄进行排序[^2]。 #### 5. 多级排序 在某些情况下,可能需要按照多个属性进行排序。可以通过 `Comparator` 的 `thenComparing` 方法实现多级排序。 ```java import java.util.*; import java.util.stream.Collectors; class Product { String name; double price; public Product(String name, double price) { this.name = name; this.price = price; } @Override public String toString() { return name + " (" + price + ")"; } } public class MultiLevelSortExample { public static void main(String[] args) { List<Product> products = Arrays.asList( new Product("Laptop", 1200), new Product("Phone", 800), new Product("Tablet", 600), new Product("Phone", 700) ); // 先按价格升序排序,再按名称降序排序 List<Product> sortedProducts = products.stream() .sorted(Comparator.comparingDouble(Product::getPrice) .thenComparing(Comparator.comparing(Product::getName).reversed())) .collect(Collectors.toList()); System.out.println(sortedProducts); // 输出: [Tablet (600), Phone (700), Phone (800), Laptop (1200)] } private static double getPrice(Product product) { return product.price; } private static String getName(Product product) { return product.name; } } ``` 此示例展示了如何通过 `Comparator.comparingDouble` 和 `thenComparing` 方法实现先按价格排序、再按名称反向排序的多级排序逻辑。 ### 总结 Java 8 的 Lambda 表达式和 Stream API 提供了灵活且简洁的方式来对集合进行排序。无论是简单的自然排序还是复杂的多级排序,都可以通过这些工具轻松实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

tiz198183

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值