如何按列(不包括第一行)对数据进行排序



我需要按第 11 列对工作表进行排序。此代码有效,但包含列标题,以便它在工作表中向下移动。

我已经尝试了以下代码

worksheet.Cells[1, 1].EntireRow.Font.Bold = true;
var startCell = (Excel.Range)worksheet.Cells[1, 1];
var endCell = (Excel.Range)worksheet.Cells[row, 12];
Excel.Range range = worksheet.Range[startCell, endCell];
range.Borders.LineStyle = Excel.XlLineStyle.xlContinuous;
range.Borders.Weight = Excel.XlBorderWeight.xlThin;
Excel.Range fullDataRange = worksheet.UsedRange;
fullDataRange.Sort(fullDataRange.Columns[11], 
Excel.XlSortOrder.xlAscending);
excelApp.ActiveWorkbook.SaveAs(txtOutputFolder.Text + "\" + 
filestart + " Instructions" + DateTime.Now.ToString(" dd.MM") + ".xlsx");
excelApp.ActiveWorkbook.Close();

如果您查看排序文档,您将看到您可以指定排序范围是否具有标题。只需在排序命令中添加一个命名参数:

fullDataRange.Sort(fullDataRange.Columns[11], Excel.XlSortOrder.xlAscending, Header:xlYes);

排序时将忽略第一行。

您可以选择所需的范围:

worksheet.Range("A1:H8")

最新更新