数据重整:用Java实现精准Excel数据排序的实用策略

news2025/1/12 5:57:10

摘要:本文由葡萄城技术团队原创并首发。转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。

前言

在数据处理或者数据分析的场景中,需要对已有的数据进行排序,在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数据进行排序的方法,如果您想了解更多有关于数据排序的玩法和技巧,可以参考这篇帮助手册,无论是初学者还是有经验的专业人士,该帮助手册都将为您提供有价值的指导和帮助。

扩展链接:

从表单驱动到模型驱动,解读低代码开发平台的发展趋势

低代码开发平台是什么?

基于分支的版本管理,帮助低代码从项目交付走向定制化产品开发

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1072781.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++day02(引用、const、函数重载、结构体、类)

今日任务 代码&#xff1a; #include <iostream> /** 自己封装一个矩形类(Rect)&#xff0c;拥有私有属性:宽度(width)、高度(height)&#xff0c;定义公有成员函数: 初始化函数:void init(int w, int h) 更改宽度的函数:set_w(int w) 更改高度的函数:set_h(int h) 输出…

Maven 环境配置

Maven 是一个基于 Java 的工具&#xff0c;所以要做的第一件事情就是安装 JDK。 系统要求 项目 要求 JDK Maven 3.3 要求 JDK 1.7 或以上 Maven 3.2 要求 JDK 1.6 或以上 Maven 3.0/3.1 要求 JDK 1.5 或以上 内存 没有最低要求 磁盘 Maven 自身安装需要大约 10 MB 空间…

SwipeRefreshLayout 下拉刷新

1.SwipeRefreshLayout是Androidx提供的下拉刷新的库&#xff0c;需要在代码中引入该库&#xff0c;才能使用。 implementation androidx.swiperefreshlayout:swiperefreshlayout:1.1.0 2.在layout中配置。SwipeRefreshLayout&#xff0c;必须包含一个根节点的子view <com.e…

5+乳酸化修饰+预后模型

今天给同学们分享一篇乳酸化修饰预后模型的生信文章“Lactylation-Related Gene Signature Effectively Predicts Prognosis and Treatment Responsiveness in Hepatocellular Carcinoma”&#xff0c;这篇文章于2023年4月25日发表在Pharmaceuticals (Basel)期刊上&#xff0c;…

spring 事物源码阅读之事务与持久化操作的结合

前面文章说到在开启事务后&#xff0c;会将数据库连接存放在当前线程的ConnectionHolder。那么后续的数据库持久化操作是怎么感知的呢。这里就要说到一个重要的类TransactionSynchronizationManager。 TransactionSynchronizationManager TransactionSynchronizationManager是…

IDEA2021创建Web项目配置Tomcat

1.新建一个普通的项目。 2.右键新建的项目&#xff0c;选择添加框架支持 3.勾选web application 4.在WEB-INF里创建lib和classes文件夹 5.file-project structure-modules-paths&#xff0c;选择use module compile output path&#xff0c;将output path和test output path的路…

Springboot知识点必知必会(一)

mvc设计模式 MVC设计模式是Model-View-Controller的缩写&#xff0c;它是一种用于设计用户界面的软件设计模式。Spring MVC是Spring框架的一个模块&#xff0c;它提供了一种基于Java的方式来实现MVC设计模式。 以下是Spring MVC中MVC设计模式的组成部分和工作原理&#xff1a; …

在Linux中通过docker安装appnode面板

先在Linux中安装docker&#xff0c;然后在docker中安装appnode面板&#xff0c;并进行docker网络端口映射。 安装docker 第一步&#xff0c;卸载旧版本docker。 若系统中已安装旧版本docker&#xff0c;则需要卸载旧版本docker以及与旧版本docker相关的依赖项。 命令&#…

计算机竞赛 : 题目:基于深度学习的水果识别 设计 开题 技术

1 前言 Hi&#xff0c;大家好&#xff0c;这里是丹成学长&#xff0c;今天做一个 基于深度学习的水果识别demo 这是一个较为新颖的竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/pos…

访问Apache Tomcat的虚拟主机管理页面

介绍 通过Tomcat Host Manager应用可以创建、删除、管理Tomcat内的虚拟主机&#xff08;virtual hosts&#xff09;。该应用是Tomcat安装的一部分&#xff0c;默认在<Tomcat安装目录>/webapps/host-manager&#xff1a; 配置用户名、密码、角色 要访问Host Manager应…

MySQL-1(12000字详解)

一&#xff1a;数据库的引入 数据库在我们以后工作中是一个非常常用的知识&#xff0c;数据库用来存储数据&#xff0c;但是有些同学可能就会疑惑了&#xff0c;存储数据用文件就可以了&#xff0c;为什么还要弄个数据库呢&#xff1f; 文件保存数据有以下几个缺点&#xff1…

Mainflux IoT:Go语言轻量级开源物联网平台,支持HTTP、MQTT、WebSocket、CoAP协议

Mainflux是一个由法国的创业公司开发并维护的安全、可扩展的开源物联网平台&#xff0c;使用 Go语言开发、采用微服务的框架。Mainflux支持多种接入设备&#xff0c;包括设备、用户、APP&#xff1b;支持多种协议&#xff0c;包括HTTP、MQTT、WebSocket、CoAP&#xff0c;并支持…

vue实现echarts中 9种 折线图图例

let datas [{ DivideScore: 7, UserScore: 7.2, Name: 目标制定 },{ DivideScore: 7, UserScore: 7, Name: 具体性 },{ DivideScore: 7, UserScore: 7.5, Name: 可衡量性 },{ DivideScore: 7, UserScore: 7, Name: 可实现性 },{ DivideScore: 7, UserScore: 7, Name: 时间限定…

【软件测试】一份合格的软件测试简历长什么样?

你可以写一篇出众的软件测试简历并且这篇测试用例能够为你带来面试电话么&#xff1f;如果没有&#xff0c;请继续阅读。我敢肯定&#xff0c;读完这篇文章&#xff0c;你将能够写出一个完美的杀手级别的软件测试和质量保证的简历&#xff0c;这将为你带来面试电话。 你的简历是…

图片调色盘

图片预览 配置安装 Color-Thief 安装包使用文档 yarn add colorthief -S // npm install colorthief --save代码 <template><div class"img-thief"><div class"container"><div class"thief-item" v-for"(item, in…

邮件误操作删除,如何找回?这里有救援方法!

用户遇到的问题 ​“邮件不慎删除&#xff0c;要如何找回呢&#xff1f;今天我在查阅邮件的过程中&#xff0c;我注意到一封带附件的邮件&#xff0c;原本是打算将其另存到其他位置&#xff0c;却无意间点击了删除&#xff0c;这之后就再也无法找回了。现在我应该怎么办&am…

java生成带logo的二维码和下方带内容的条形码

一、导入zxing包 <!-- zxing --><dependency><groupId>com.google.zxing</groupId><artifactId>core</artifactId><version>3.5.2</version></dependency><dependency><groupId>com.google.zxing</group…

【数据结构】归并排序和计数排序(排序的总结)

目录 一&#xff0c;归并排序的递归 二&#xff0c;归并排序的非递归 三&#xff0c;计数排序 四&#xff0c;排序算法的综合分析 一&#xff0c;归并排序的递归 基本思想&#xff1a; 归并采用的是分治思想&#xff0c;是分治法的一个经典的运用。该算法先将原数据进行拆…

what?es数据偏移了8小时...

今天搞监控大屏的时候&#xff0c;测试突然提出一个问题说&#xff0c;查一段时间的数据&#xff0c;时间曲线返回的日期有时候会比查询时间多&#xff0c;翻看代码后&#xff0c;初步定位为es的时区问题&#xff0c;后来将时间曲线的直方图聚合增加时区后&#xff0c;返回数据…

android studio 、JDK环境变量配置

1、adb.exe环境变量配置&#xff1a; 打开控制面板 >系统和安全>系统>高级系统设置 在系统变量中新建ANDROID_HOME变量&#xff0c;赋值路径&#xff1a;D:\install\androidSDK 在系统变量path中添加&#xff1a;%ANDROID_HOME%\platform-tools 校验是…