tLayerDtos.stream().sorted(Comparator.comparing(TLayer::getFloor)).forEach根据floor来排序,但是"floor": "33333楼"排在了"floor": "3楼"前面这怎么办
时间: 2023-10-16 18:13:44 浏览: 108
在这种情况下,可以使用自定义的 Comparator 来实现根据纯数字排序。例如,可以编写一个方法来从字符串中提取数字并进行比较:
```
private static int extractNumber(String s) {
String digits = s.replaceAll("\\D+", "");
return digits.isEmpty() ? 0 : Integer.parseInt(digits);
}
Comparator<TLayer> floorComparator = Comparator.comparing(t -> extractNumber(t.getFloor()));
tLayerDtos.stream().sorted(floorComparator).forEach(System.out::println);
```
这个方法使用正则表达式将字符串中的非数字字符替换为空字符串,并将结果转换为整数。然后,我们可以使用这个方法来创建一个根据数字排序的 Comparator。
相关问题
List<OrderListVo> collect = list.stream().sorted(Comparator.comparing(OrderListVo::getCreateTime).reversed()).collect(Collectors.toList()); 实现根据getCreateTime 进行排序 并且最大事件的为1 依次累加 java
可以使用`IntStream.range()`和`forEach()`方法来实现对排序后的列表中的元素进行编号,并将编号赋给`OrderListVo`类中的另一个属性。下面是示例代码:
```
List<OrderListVo> collect = list.stream()
.sorted(Comparator.comparing(OrderListVo::getCreateTime).reversed())
.collect(Collectors.toList());
int maxIndex = Math.min(collect.size(), 1);
IntStream.range(0, maxIndex).forEach(i -> collect.get(i).setRank(i + 1));
IntStream.range(maxIndex, collect.size()).forEach(i -> {
OrderListVo prev = collect.get(i - 1);
OrderListVo current = collect.get(i);
if (current.getCreateTime().equals(prev.getCreateTime())) {
current.setRank(prev.getRank());
} else {
current.setRank(prev.getRank() + 1);
}
});
```
首先将原始列表按照`getCreateTime`排序后,使用`IntStream.range()`方法生成一个数字区间,区间的长度为1或原始列表的长度(取决于哪个更小),然后使用`forEach()`方法将区间中的数字i逐个取出,并使用`collect.get(i)`获取排序后的列表中的元素。对于取出的元素,如果i小于最大事件1,则将其rank属性赋为i+1;否则,将其rank属性与前一个元素的rank属性进行比较,如果创建时间相同,就将其rank属性赋为前一个元素的rank属性,否则将其rank属性赋为前一个元素的rank属性加1。
Map<String, Map<String, List<String>>> tag2AllFunds = Maps.newHashMap(); Comparator comparator = Collator.getInstance(Locale.CHINA); tag2AllFunds.forEach((key,value) ->{ value.keySet().stream() .sorted(Comparator.comparing(k -> value.get(k).size()).reversed().thenComparing(comparator)) .collect(Collectors.toMap( en -> value.get(en), Map.Entry::getValue)); }); 修改正确这段代码
这段代码有一些问题,因为在 `collect` 方法中使用了 `en -> value.get(en)`,这是错误的,因为它应该返回键而不是值。另外,`toMap` 方法需要指定一个合并函数,因为在排序后可能会有重复的键。正确的代码如下:
```
Map<String, Map<String, List<String>>> tag2AllFunds = Maps.newHashMap();
Comparator<String> comparator = Collator.getInstance(Locale.CHINA);
tag2AllFunds.forEach((key, value) -> {
value.entrySet().stream()
.sorted(Comparator.comparing((Map.Entry<String, List<String>> entry) -> entry.getValue().size())
.reversed()
.thenComparing(Map.Entry.comparingByKey(comparator)))
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue, (v1, v2) -> v1, LinkedHashMap::new));
});
```
这里我们使用了 `entrySet` 方法来获取键值对,然后使用 `Map.Entry` 的 `comparingByKey` 方法来按键排序。在 `toMap` 方法中,我们使用了一个合并函数,它将两个值合并为一个。此外,我们还使用了一个 `LinkedHashMap` 来保留顺序。
阅读全文