hutool List<Map<int,Object>> 排序
时间: 2023-08-10 12:04:58 浏览: 55
你可以使用Hutool中的`CollUtil`类中的`sort`方法来对`List<Map<Integer, Object>>`进行排序。具体实现可以参考以下代码示例:
```java
List<Map<Integer, Object>> list = new ArrayList<>();
// 往List中添加Map元素
// 对List进行排序,以Map中的某个键值为排序依据
CollUtil.sort(list, (o1, o2) -> {
Integer value1 = (Integer) o1.get("key");
Integer value2 = (Integer) o2.get("key");
return value1.compareTo(value2);
});
```
其中,第二个参数是一个`Comparator`接口的实现,用于指定排序规则。在上面的示例中,我们按照Map中的"key"键值进行排序。你可以根据实际需求,修改排序规则。
相关问题
java 中 List<Map<String, Object>> 进行排序
在Java中,可以使用Comparator工具类对List<Map<String, Object>>进行排序。下面是一个示例代码:
```java
import java.util.*;
public class Main {
public static void main(String[] args) {
List<Map<String, Object>> list = new ArrayList<>();
// 添加Map数据
Map<String, Object> map1 = new HashMap<>();
map1.put("name", "John");
map1.put("age", 25);
list.add(map1);
Map<String, Object> map2 = new HashMap<>();
map2.put("name", "Alice");
map2.put("age", 30);
list.add(map2);
Map<String, Object> map3 = new HashMap<>();
map3.put("name", "Bob");
map3.put("age", 20);
list.add(map3);
// 使用Comparator对List<Map<String, Object>>进行排序
Collections.sort(list, new Comparator<Map<String, Object>>() {
@Override
public int compare(Map<String, Object> o1, Map<String, Object> o2) {
// 根据键值进行排序,这里以name为例
String name1 = (String) o1.get("name");
String name2 = (String) o2.get("name");
return name1.compareTo(name2);
}
});
// 输出排序后的结果
for (Map<String, Object> map : list) {
System.out.println(map);
}
}
}
```
这段代码首先创建了一个List<Map<String, Object>>,然后向其中添加了三个Map对象。接下来使用Collections.sort()方法对List进行排序,传入一个Comparator对象来指定排序规则。在Comparator的compare()方法中,我们根据Map中的某一键值进行比较,这里以name为例。最后,通过遍历List输出排序后的结果。
hutool List<Map<int,Object>> 排序,特定值放前面
如果你要对`List<Map<Integer, Object>>`进行排序,并且想把其中某个键值为特定值的元素放到最前面,可以使用Hutool的`CollUtil`类中的`sort`方法结合`CollUtil.sortByProperty`方法来实现。具体实现可以参考以下代码示例:
```java
List<Map<Integer, Object>> list = new ArrayList<>();
// 往List中添加Map元素
// 对List进行排序,以Map中的某个键值为排序依据,其中特定值放到最前面
CollUtil.sort(list, (o1, o2) -> {
Integer value1 = (Integer) o1.get("key");
Integer value2 = (Integer) o2.get("key");
// 如果o1的键值为特定值,返回-1,即o1排在o2前面;如果o2的键值为特定值,返回1,即o2排在o1前面;否则按照键值大小升序排序
return value1.equals(特定值) ? -1 : value2.equals(特定值) ? 1 : value1.compareTo(value2);
});
```
在上面的示例中,我们使用`CollUtil.sortByProperty`方法指定了排序规则,如果某个元素的"key"键值为特定值,我们就返回-1,让该元素排在前面;如果另一个元素的"key"键值为特定值,我们就返回1,让该元素排在后面;否则按照键值大小升序排序。你可以根据实际需求修改排序规则。