ClosedXML - 添加新行而不覆盖数据(第一行)

本文关键字:一行 数据 覆盖 添加 新行 ClosedXML | 更新日期: 2023-09-27 18:34:10

我正在尝试在填写 excel 文档之前添加一个空行。

using (DataTable dt = new DataTable())
{
    sda.Fill(dt);
    using (XLWorkbook wb = new XLWorkbook())
    {
        var ws = wb.Worksheets.Add(dt, "Report");
        var listOfStrings = new List<String>();
        ws.Cell(1, 6).Value = "Service";
        ws.Cell(1, 15).Value = "Invoice";
        ws.Range("A1:L1").Style.Fill.BackgroundColor = XLColor.DarkBlue;
        ws.Range("M1:Q1").Style.Fill.BackgroundColor = XLColor.DarkCandyAppleRed;
        ws.Range("M2:Q2").Style.Fill.BackgroundColor = XLColor.Red;
        Response.Clear();
        Response.Buffer = true;
        Response.Charset = "";
        Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
        Response.AddHeader("content-disposition", "attachment;filename=Report.xlsx");
        using (MemoryStream MyMemoryStream = new MemoryStream())
        {
            wb.SaveAs(MyMemoryStream);
            MyMemoryStream.WriteTo(Response.OutputStream);
            Response.Flush();
            Response.End();
        }
    }
}

我只需要将第一行设为空,然后用我的数据填充文档。但是我一直在覆盖文档。

ClosedXML - 添加新行而不覆盖数据(第一行)

要在工作表中的第一行上方插入一行,请使用以下命令:

ws.Row(1).InsertRowsAbove(1);
                       // ^ number of rows to insert

还有一种方法InsertRowsBelow()在某一行下方插入新行。有关更多示例,请参阅文档。