数据重整:用Java实现精准Excel数据排序的实用策略
摘要:本文由葡萄城技术团队原创并首发。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。
前言
在数据处理或者数据分析的场景中,需要对已有的数据进行排序,在Excel中可以通过排序功能进行整理数据。而在Java中,则可以借助Excel表格插件对数据进行批量排序,下面是一些常见的数据排序方法:
- 按值排序
- 按图标排序
- 按字体颜色排序
- 按背景色排序
- 根据自定义序列排序
下面小编将为大家介绍如何使用Java分别实现上述的Excel数据排序。
样例数据
为了方便展示,先准备一些样例数据,用于排序,定义一个方法,传入workbook,在上面添加如下数据。
private void SetExampleData(Workbook wb) {
   Object data = new Object[][]{
       {"Name", "City", "Birthday", "Eye color", "Weight", "Height"},
       {"Richard", "New York", new GregorianCalendar(1968, 5, 8), "Blue", 67, 165},
       {"Nia", "New York", new GregorianCalendar(1972, 6, 3), "Brown", 62, 134},
       {"Jared", "New York", new GregorianCalendar(1964, 2, 2), "Hazel", 72, 180},
       {"Natalie", "Washington", new GregorianCalendar(1972, 7, 8), "Blue", 66, 163},
       {"Damon", "Washington", new GregorianCalendar(1986, 1, 2), "Hazel", 76, 176},
       {"Angela", "Washington", new GregorianCalendar(1993, 1, 15), "Brown", 68, 145}
   };
   IWorksheet sheet = wb.getWorksheets().get(0);
   sheet.getRange("A1:F7").setValue(data);
   sheet.getRange("A:F").setColumnWidth(15);
   wb.save("output/sampleData.xlsx");
 }
样例数据如下所示:
1. 按值排序
按值排序是指根据单元格值按特定顺序排列数据的排序操作。setOrientation方法用于指定排序的方向类别,即列或行。
public void SortByValue() {
   Workbook wb = new Workbook();
   SetExampleData(wb);
   IWorksheet sheet = wb.getActiveSheet();
   //对F列做升序排序.
   sheet.getRange("A2:F7").sort(sheet.getRange("F2:F7"), SortOrder.Ascending, SortOrientation.Columns);
   wb.save("output/sortByValue.xlsx");
 }
实现效果如下图所示: 
2. 按图标排序
按图标排序是指基于单元格的条件格式图标执行的排序操作。
public void SortByIcon() {
   Workbook wb = new Workbook();
   SetExampleData(wb);
   IWorksheet sheet = wb.getActiveSheet();
   IIconSetCondition iconset = sheet.getRange("F2:F27").getFormatConditions().addIconSetCondition();
   iconset.setIconSet(wb.getIconSets().get(IconSetType.Icon3TrafficLights1));
   sheet.getSort().getSortFields().add(new IconSortField(sheet.getRange("F2:F7"),
       wb.getIconSets().get(IconSetType.Icon3TrafficLights1).get(2), SortOrder.Ascending));
   sheet.getSort().setRange(sheet.getRange("A2:F7"));
   sheet.getSort().setOrientation(SortOrientation.Columns);
   sheet.getSort().apply();
   wb.save("output/sortByIcon.xlsx");
 }
实现效果如下图所示: 
3. 按字体颜色排序
按字体颜色排序是指根据单元格的显示格式和字体颜色执行的排序操作。
public void SortByFontColor() {
   Workbook wb = new Workbook();
   SetExampleData(wb);
   IWorksheet sheet = wb.getActiveSheet();
   sheet.getRange("F2").getFont().setColor(Color.GetRed());
   sheet.getRange("F3").getFont().setColor(Color.GetGainsboro());
   sheet.getRange("F4").getFont().setColor(Color.GetGreen());
   sheet.getRange("F5").getFont().setColor(Color.GetGainsboro());
   sheet.getRange("F6").getFont().setColor(Color.GetGainsboro());
   sheet.getRange("F7").getFont().setColor(Color.GetGainsboro());
   sheet.getSort().getSortFields().add(new FontColorSortField(sheet.getRange("F2:F7"),
       sheet.getRange("F7").getFont().getColor(), SortOrder.Ascending));
   sheet.getSort().setRange(sheet.getRange("A2:F7"));
   sheet.getSort().setOrientation(SortOrientation.Columns);
   sheet.getSort().apply();
   wb.save("output/sortByFontColor.xlsx");
 }
实现效果如下图所示: 
4. 按背景色排序
按背景颜色排序是指根据单元格的背景颜色进行排序的操作。
public void SortByBackgroundColor() {
   Workbook wb = new Workbook();
   SetExampleData(wb);
   IWorksheet sheet = wb.getActiveSheet();
   sheet.getRange("F2").getInterior().setColor(Color.GetLightPink());
   sheet.getRange("F3").getInterior().setColor(Color.GetLightGreen());
   sheet.getRange("F4").getInterior().setColor(Color.GetLightPink());
   sheet.getRange("F5").getInterior().setColor(Color.GetLightGreen());
   sheet.getRange("F6").getInterior().setColor(Color.GetLightBlue());
   sheet.getRange("F7").getInterior().setColor(Color.GetLightPink());
   sheet.getSort().getSortFields().add(new CellColorSortField(sheet.getRange("F2:F7"),
       sheet.getRange("F4").getDisplayFormat().getInterior(), SortOrder.Ascending));
   sheet.getSort().setRange(sheet.getRange("A2:F7"));
   sheet.getSort().setOrientation(SortOrientation.Columns);
   sheet.getSort().apply();
   wb.save("output/sortByBackgroundColor.xlsx");
 }
实现效果如下图所示: 
5. 根据自定义序列排序
public void CustomSort() {
   Workbook wb = new Workbook();
   SetExampleData(wb);
   IWorksheet sheet = wb.getActiveSheet();
   ValueSortField sortkey = new ValueSortField(sheet.getRange("A2:A7"), "\"Angela\", \"Damon\"");
   sheet.getRange("A2:F7").sort(SortOrientation.Columns, false, sortkey);
   wb.save("output/customSort.xlsx");
 }
实现效果如下图所示: 
总结
以上就是在Java中对Excel数据进行排序的方法,如果您想了解更多有关于数据排序的玩法和技巧,可以参考这篇帮助手册,无论是初学者还是有经验的专业人士,该帮助手册都将为您提供有价值的指导和帮助。
扩展链接:
 关注公众号
关注公众号
					低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 
							
								
								    上一篇
								      这道面试题工作中经常碰到,但 99% 的程序员都答不上来小时候都被问过一个脑筋急转弯,把大象放进冰箱有几个步骤?我们一开始都会抓耳挠腮,去想着该如何把大象塞进冰箱。最终揭晓的答案却根本不关心具体的操作方法,只是提供了 3 个步骤组成的流程,「把冰箱打开,把大象放进去,再把冰箱关上」。而对于每一位开发者来说,变更数据库字段是绕不过去的操作。而当被问及需要几步时,不少人都会脱口而出 1 步, 不就是执行一条 ALTER TABLE 语句嘛。 这当然不是一道脑筋急转弯题,但确实是一道经典的技术面试题,而答 1 步的同学,基本就挂掉了。实际上,一个标准的数据库字段变更操作需要分成很多步,比如给字段重命名,会分成 6 步: 创建一个使用新名字的字段 更新应用,同时双写 (dual-write)旧字段和新字段 把启动双写前,旧字段的数据回填 (backfill) 到新字段 当回填结束后,添加诸如 NOT NULL 之类的约束到新字段 更新应用,移除所有对于旧字段的依赖,只使用新字段 删除旧名字的字段 以上只是一个大致的执行步骤,而具体的执行细节多到值得许多公司都会单独撰文 有关如何做数据库变更的讨论一直也是 HN 上的热点话题 两年多前,Bytebas... 
- 
							
								
								    下一篇
								      手敲,Ascend算子开发入门笔记分享本文分享自华为云社区《Ascend算子开发入门笔记》,作者: JeffDing 。 基础概念 什么是Ascend C Ascend C是CANN针对算子开发场景推出的编程语言,原生支持C和C++标准规范,最大化匹配用户开发习惯;通过多层接口抽象、自动并行计算、孪生调试等关键技术,极大提高算子开发效率,助力AI开发者低成本完成算子开发和模型调优部署。 使用Ascend C开发自定义算子的优势 C/C++原语编程,最大化匹配用户的开发习惯 编程模型屏蔽硬件差异,编程范式提高开发效率 多层级API封装,从简单到灵活,兼顾易用与高效 孪生调试,CPU侧模拟NPU侧的行为,可优化在CPU侧调试 昇腾计算架构CANN CANN 介绍网站:https://www.hiascend.com/software/cann AI Core是NPU卡的计算核心,NPU内部有多个AI Core。每个AI Core相当于多核CPU中的一个核心 SIMD SIMD,也就是单指令多数据计算,一条指令可以处理多个数据:Ascend C编程API主要是向量计算API和矩阵运算API,计算API都是SIMD样式 并行计算之... 
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- 面试大杂烩
- Red5直播服务器,属于Java语言的直播服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- MySQL表碎片整理

 
			





 
				 
				 
				 
				 
				 
				 
				



 微信收款码
微信收款码 支付宝收款码
支付宝收款码