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. 按圖標排序
按圖標排序是指基于單元格的條件格式圖標執(zhí)行的排序操作。
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. 按字體顏色排序
按字體顏色排序是指根據單元格的顯示格式和字體顏色執(zhí)行的排序操作。
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數據排序的方法詳解的文章就介紹到這了,更多相關Java Excel數據排序內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
自定義JmsListenerContainerFactory時,containerFactory字段解讀
這篇文章主要介紹了自定義JmsListenerContainerFactory時,containerFactory字段解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07SpringBoot MainApplication類文件的位置詳解
這篇文章主要介紹了SpringBoot MainApplication類文件的位置詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01SpringMVC訪問controller報錯404的解決辦法(總結超詳細)
純注解配置SpringMVC程序,使用tomcat8.5.95版本啟動,能啟動成功并且訪問index.jsp頁面,但是訪問/save時出現404無法訪問,本文給大家介紹了SpringMVC訪問controller報錯404的解決辦法,文章總結的非常詳細,需要的朋友可以參考下2024-05-05idea 安裝 Mybatis 開發(fā)幫助插件 MyBatisCodeHelper-Pro 插件破解版的方法
MyBatisCodeHelper-Pro 插件可以幫助我們快速的開發(fā) mybatis,這篇文章給大家介紹idea 安裝 Mybatis 開發(fā)幫助插件 MyBatisCodeHelper-Pro 插件破解版的相關知識,感興趣的朋友跟隨小編一起看看吧2020-09-09