Сортировка данных

Сортировка данных в Microsoft Excel

Чтобы отсортировать данные в Microsoft Excel:

  1. Выберите Данные в меню Сортировка. В диалоговом окне сортировки будет отображаться.
  2. Выберите вариант сортировки.

Обычно сортировка выполняется в списке - это непрерывная группа данных, отображаемых в столбцах.

Сортировка данных с помощью Aspose.Cells

Aspose.Cells for Node.js via C++ предоставляет класс DataSorter, используемый для сортировки данных в порядке возрастания или убывания. Этот класс имеет важные члены, например, свойства Key1 … Key3 и Order1 … Order3. Эти члены используются для определения ключей сортировки и указания порядка сортировки ключей.

Перед реализацией сортировки данных необходимо определить ключи и установить порядок сортировки. В классе предоставляется метод DataSorter.sort, используемый для выполнения сортировки данных на основе данных ячейки на листе таблицы.

Метод DataSorter.sort принимает следующие параметры:

  • Cells, ячейки для основного листа таблицы.
  • CellArea, диапазон ячеек. Определите область ячеек перед применением сортировки данных.

В этом примере используется шаблонный файл “Book1.xls”, созданный в Microsoft Excel. После выполнения приведенного ниже кода данные сортируются правильно.

//For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
const AsposeCells = require("aspose.cells.node");
// Instantiate a new Workbook object.
// Load a template file.
var workbook = new AsposeCells.Workbook("book1.xls");
// Get the workbook datasorter object.
var sorter = workbook.getDataSorter();
// Set the first order for datasorter object.
sorter.setOrder1(AsposeCells.SortOrder.Descending);
// Define the first key.
sorter.setKey1(0);
// Set the second order for datasorter object.
sorter.setOrder2(AsposeCells.SortOrder.Ascending);
// Define the second key.
sorter.setKey2(1);
// Create a cells area (range).
var ca = new AsposeCells.CellArea();
// Specify the start row index.
ca.startRow = 0;
// Specify the start column index.
ca.startColumn = 0;
// Specify the last row index.
ca.endRow = 13;
// Specify the last column index.
ca.endColumn = 1;
// Sort data in the specified data range (A1:B14)
sorter.sort(workbook.getWorksheets().get(0).getCells(), ca);
// Save the excel file.
workbook.save("output.out.xls");

Сортировка данных с цветом фона

Excel предоставляет функции сортировки данных по цвету фона. Та же функция реализована через Aspose.Cells for Node.js via C++ с помощью DataSorter, в котором SortOnType.CellColor можно использовать в DataSorter.addKey для сортировки данных по цвету фона. Все ячейки с указанным цветом в DataSorter.addKey, функция помещает сверху или снизу в соответствии с настройкой SortOrder, а порядок остальных ячеек при этом не меняется.

Ниже приведены образцовые файлы, которые можно загрузить для тестирования этой функции:

sampleBackGroundFile.xlsx

outputsampleBackGroundFile.xlsx

//For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
const AsposeCells = require("aspose.cells.node");
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET
// Create a workbook object and load template file
var workbook = new AsposeCells.Workbook("CellsNet46500.xlsx");
// Instantiate data sorter object
var sorter = workbook.getDataSorter();
// Add key for second column for red color
sorter.addKey(1, AsposeCells.SortOnType.CellColor, AsposeCells.SortOrder.Descending, AsposeCells.Color.Red);
// Sort the data based on the key
sorter.sort(workbook.getWorksheets().get(0).getCells(), AsposeCells.CellArea.createCellArea("A2", "C6"));
// Save the output file
workbook.save("outputSortData_CustomSortList.xlsx");

Продвинутые темы