Guava排序-Guava实现多列排序

2024-05-14 15:18
文章标签 实现 排序 guava 多列

本文主要是介绍Guava排序-Guava实现多列排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Guava排序:ComparisonChain

这里我先说一下我的一个需求,然后对照着需求来说一下如何实现对应的逻辑。

首先我有一个List

// 姓名,性别,年龄,薪资,级别,籍贯
List<List<Object>> lists = Lists.newArrayList();lists.add(Arrays.asList("张三", "男", 22, 10000, "T2", "贵州遵义"));
lists.add(Arrays.asList("李四", "女", 23, 11000, "T2", "贵州遵义"));
lists.add(Arrays.asList("王五", "女", 23, 12000, "T3", "北京海淀"));
lists.add(Arrays.asList("王六", "男", 23, 13000, "T3", "北京昌平"));
lists.add(Arrays.asList("王七", "男", 24, 14000, "T3", "北京昌平"));
lists.add(Arrays.asList("王八", "女", 23, 12000, "T2", "北京昌平"));
lists.add(Arrays.asList("胡三", "男", 26, 12000, "T3", "北京朝阳"));
lists.add(Arrays.asList("胡四", "男", 26, 13000, "T3", "北京朝阳"));
lists.add(Arrays.asList("张五", "女", 26, 14000, "T3", "北京海淀"));
lists.add(Arrays.asList("张六", "男", 27, 17000, "T4", "北京朝阳"));
lists.add(Arrays.asList("张七", "男", 23, 12000, "T3", "北京朝阳"));
lists.add(Arrays.asList("黄五", "女", 24, 11000, "T2", "北京海淀"));
lists.add(Arrays.asList("黄三", "男", 24, 10000, "T2", "北京大兴"));
lists.add(Arrays.asList("刘爱", "男", 22, 9000, "T1", "北京大兴"));
lists.add(Arrays.asList("刘跟", "男", 27, 18000, "T4", "贵州遵义"));
lists.add(Arrays.asList("李根", "男", 28, 20000, "T5", "贵州贵阳"));
lists.add(Arrays.asList("郭艾琳", "男", 24, 12000, "T3", "贵州贵阳"));

现在我想要对这些数据进行一次排序,根据年龄、薪资和级别来排序。也就是说对三列进行排序,如果数据存在库里面,那肯定是可以直接order by,但是我现在的数据是在内存里面,如何排序呢?

这里就可以使用到了Guava的ComparisonChain,ComparisonChain是一个链式排序逻辑,把需要排序的列先后往ComparisonChain中添加即可,主要的代码:

...
public abstract <T> ComparisonChain compare(@NullableDecl T var1, @NullableDecl T var2, Comparator<T> var3);
...

排序实例:

private static Comparator<List<Object>> listComparator(Map<Integer, Boolean> colSortMaps) {Ordering ordering = Ordering.natural();return (list1, list2) -> {ComparisonChain compareChain = ComparisonChain.start();for (Integer index : colSortMaps.keySet()) {Object currObj = Optional.ofNullable(list1.get(index)).orElse("");Object compObj = Optional.ofNullable(list2.get(index)).orElse("");Comparator<Object> objComparator = objComparator(ordering, colSortMaps.getOrDefault(index, true));compareChain = compareChain.compare(currObj, compObj, objComparator);}return compareChain.result();};}private static Comparator<Object> objComparator(Ordering ordering, boolean asc) {if (asc) {return ordering::compare;} else {return ordering.reverse()::compare;}
}

其中Map colSortMaps这个参数表示列序号和是否升序的Map,调用排序:

Map<Integer, Boolean> colSortMaps = Maps.newHashMap();
colSortMaps.put(2, true); // 年龄升序
colSortMaps.put(3, true); // 薪资升序
colSortMaps.put(4, true); // 级别升序lists.sort(listComparator(colSortMaps));

排序结果:

刘爱,男,22,9000,T1,北京大兴
张三,男,22,10000,T2,贵州遵义
李四,女,23,11000,T2,贵州遵义
王八,女,23,12000,T2,北京昌平
王五,女,23,12000,T3,北京海淀
张七,男,23,12000,T3,北京朝阳
王六,男,23,13000,T3,北京昌平
黄三,男,24,10000,T2,北京大兴
黄五,女,24,11000,T2,北京海淀
郭艾琳,男,24,12000,T3,贵州贵阳
王七,男,24,14000,T3,北京昌平
胡三,男,26,12000,T3,北京朝阳
胡四,男,26,13000,T3,北京朝阳
张五,女,26,14000,T3,北京海淀
张六,男,27,17000,T4,北京朝阳
刘跟,男,27,18000,T4,贵州遵义
李根,男,28,20000,T5,贵州贵阳

Guava是一个Java神库,源码也写的非常好,多看Guava的源码也使我收获了不少,希望交流,多多进步。

这篇关于Guava排序-Guava实现多列排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/989094

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

hdu 1285(拓扑排序)

题意: 给各个队间的胜负关系,让排名次,名词相同按从小到大排。 解析: 拓扑排序是应用于有向无回路图(Direct Acyclic Graph,简称DAG)上的一种排序方式,对一个有向无回路图进行拓扑排序后,所有的顶点形成一个序列,对所有边(u,v),满足u 在v 的前面。该序列说明了顶点表示的事件或状态发生的整体顺序。比较经典的是在工程活动上,某些工程完成后,另一些工程才能继续,此时