Сортировка данных
Сортировка данных в Microsoft Excel
Чтобы отсортировать данные в Microsoft Excel:
- ВыбиратьДанные отСортировать меню. Появится диалоговое окно Сортировка.
- Выберите вариант сортировки.
Как правило, сортировка выполняется в списке, определяемом как непрерывная группа данных, где данные отображаются в столбцах.
Сортировка данных с Aspose.Cells
Aspose.Cells обеспечиваетсортировщик данныхкласс, используемый для сортировки данных в порядке возрастания или убывания. У класса есть несколько важных членов, например такие свойства, как Key1 … Key3 и Order1 … Order3. Эти элементы используются для определения отсортированных ключей и порядка сортировки ключей.
Вы должны определить ключи и установить порядок сортировки перед реализацией сортировки данных. Класс предоставляетСортироватьметод, используемый для выполнения сортировки данных на основе данных ячеек на листе.
Сортироватьметод принимает следующие параметры:
- Aspose.Cells.Cells, ячейки для основного рабочего листа.
- Aspose.Cells.CellArea, диапазон ячеек. Определите область ячейки перед применением сортировки данных.
В этом примере используется файл шаблона «Book1.xls», созданный в Microsoft Excel. После выполнения приведенного ниже кода данные сортируются соответствующим образом.
// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET | |
// The path to the documents directory. | |
string dataDir = RunExamples.GetDataDir(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); | |
// Instantiate a new Workbook object. | |
// Load a template file. | |
Workbook workbook = new Workbook(dataDir + "book1.xls"); | |
// Get the workbook datasorter object. | |
DataSorter sorter = workbook.DataSorter; | |
// Set the first order for datasorter object. | |
sorter.Order1 = Aspose.Cells.SortOrder.Descending; | |
// Define the first key. | |
sorter.Key1 = 0; | |
// Set the second order for datasorter object. | |
sorter.Order2 = Aspose.Cells.SortOrder.Ascending; | |
// Define the second key. | |
sorter.Key2 = 1; | |
// Create a cells area (range). | |
CellArea ca = new 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.Worksheets[0].Cells, ca); | |
// Save the excel file. | |
workbook.Save(dataDir + "output.out.xls"); |
Сортировка данных по цвету фона
Excel предоставляет функции для сортировки данных по цвету фона. Та же функция предоставляется с использованием Aspose.Cells с использованием DataSorter, гдеСортировка по типу .CellColor можно использовать вДобавитьКлюч() для сортировки данных по цвету фона. Все ячейки, содержащие указанный цвет вДобавитьКлюч(), функция размещается сверху или снизу в соответствии с настройкой SortOrder, а порядок остальных ячеек вообще не меняется.
Ниже приведены примеры файлов, которые можно загрузить для тестирования этой функции:
outputsampleBackGroundFile.xlsx
// 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 | |
Workbook workbook = new Workbook(sourceDir + "CellsNet46500.xlsx"); | |
// Instantiate data sorter object | |
DataSorter sorter = workbook.DataSorter; | |
// Add key for second column for red color | |
sorter.AddKey(1, SortOnType.CellColor, SortOrder.Descending, Color.Red); | |
// Sort the data based on the key | |
sorter.Sort(workbook.Worksheets[0].Cells, CellArea.CreateCellArea("A2", "C6")); | |
// Save the output file | |
workbook.Save(outputDir + "outputSortData_CustomSortList.xlsx"); |