• 数据重整:用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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    样例数据如下所示:

    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");
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    实现效果如下图所示:

    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");
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    实现效果如下图所示:

    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");
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    实现效果如下图所示:

    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");
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    实现效果如下图所示:

    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");
     }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    实现效果如下图所示:

    总结

    以上就是在Java中对Excel数据进行排序的方法,如果您想了解更多有关于数据排序的玩法和技巧,可以参考这篇帮助手册,无论是初学者还是有经验的专业人士,该帮助手册都将为您提供有价值的指导和帮助。

    扩展链接:

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

    低代码开发平台是什么?

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

  • 相关阅读:
    怎样正确做 Web 应用的压力测试?
    【特征重要性揭秘:为什么同一个数据集会有不同结果】
    docker 操作指南
    电脑如何下载视频号的视频?电脑微信视频号使用的方法!
    2.1 初探大数据
    socket 降低cpu 占用率 ,放弃Thread和Whell 循环
    从0开始编写BP,自适应学习率的BP神经网络,不使用MATLAB工具箱,纯手写matlab代码,以BP分类为例...
    RabbitMQ--基础--7.2--工作模式--工作队列
    【云原生之Docker实战】使用Docker部署Trilium个人笔记工具
    基于DoS攻击能量分级的ICPS综合安全控制与通信协同设计
  • 原文地址:https://blog.csdn.net/powertoolsteam/article/details/133378943