Сортировка данных в столбце с пользовательским списком сортировки
Возможные сценарии использования
Вы можете отсортировать данные в столбце, используя пользовательский список. Для этого используется метод DataSorter.AddKey(int key, SortOrder order, String customList). Однако этот метод работает только в том случае, если элементы в пользовательском списке не содержат запятых внутри них. Если они содержат запятые, например, “USA, US”, “China, CN” и т. д., то необходимо использовать метод DataSorter.AddKey(int key, SortOrder order, String customList). Здесь последний параметр не является строкой, а массивом строк.
Сортировка данных в столбце с пользовательским списком
В следующем образце кода объясняется, как использовать метод DataSorter.AddKey(int key, SortOrder order, String[] customList) для сортировки данных с помощью пользовательского списка сортировки. Пожалуйста, ознакомьтесь с образцом Excel-файла, используемым в этом коде, и выходным Excel-файлом, сгенерированным им. Ниже показан эффект кода на образец Excel-файла при выполнении.
Образец кода
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java | |
//Load the source Excel file | |
Workbook wb = new Workbook(srcDir + "sampleSortData_CustomSortList.xlsx"); | |
//Access first worksheet | |
Worksheet ws = wb.getWorksheets().get(0); | |
//Specify cell area - sort from A1 to A40 | |
CellArea ca = CellArea.createCellArea("A1", "A40"); | |
//Create Custom Sort list | |
String[] customSortList = new String[] { "USA,US", "Brazil,BR", "China,CN", "Russia,RU", "Canada,CA" }; | |
//Add Key for Column A, Sort it in Ascending Order with Custom Sort List | |
wb.getDataSorter().addKey(0, SortOrder.ASCENDING, customSortList); | |
wb.getDataSorter().sort(ws.getCells(), ca); | |
//Save the output Excel file | |
wb.save(outDir + "outputSortData_CustomSortList.xlsx"); |