簡體   English   中英

從特定列 C# 將數據表導出到 Excel Strat

[英]Export Datatable into Excel Strat from Specific Column C#

我有一個數據表,我想將數據導出到 excel 但開始從特定列導出。 場景,我有一張 excel 表,前 5 列 [AE] 有數據,想從數據表中導出,應該從列-F 開始。 如何在 C# 控制台應用程序中實現這一點。

因此,這里最明顯的方法是遍歷數據表的行並將每個行手動寫入 Excel 表:

Microsoft.Office.Interop.Excel.Application oXL;
Microsoft.Office.Interop.Excel._Workbook oWB;
Microsoft.Office.Interop.Excel._Worksheet oSheet;

// Start Excel and get Application object.
oXL = new Microsoft.Office.Interop.Excel.Application();
oXL.Visible = true;

// Get a new workbook.
oWB = (Microsoft.Office.Interop.Excel._Workbook)(oXL.Workbooks.Add(""));
oSheet = (Microsoft.Office.Interop.Excel._Worksheet)oWB.ActiveSheet;

// Write the data. Remember that Excel is 1-indexed
int rowIndex = 1;
foreach (DataRow row in table.Rows) {
    int colIndex = 6;
    foreach (DataColumn col in table.Columns) {
        oSheet.Cells[rowIndex, colIndex] = row[col];
        colIndex++;
    }

    rowIndex++;
}

// Save the Excel file
oXL.Visible = false;
oXL.UserControl = false;
oWB.SaveAs("c:\\test\\test505.xls", Microsoft.Office.Interop.Excel.XlFileFormat.xlWorkbookDefault, Type.Missing, Type.Missing,
    false, false, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
    Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

// Exit Excel
oWB.Close();
oXL.Quit();

這個問題可能有一個更優雅的解決方案,但我認為這至少可以完成工作。 作為參考,我的 Excel 代碼是從這個問題修改的,因此您可能可以在那里找到更適合您特定需求的匹配項。

您可以使用 ClosedXML 庫。 我的代碼中的示例

        var wb = new XLWorkbook();
        var ws = wb.Worksheets.Add("My Sheet 1");

        ws.Cell("A8").Value = "Print by Admin:";
        ws.Cell("B8").Value = $"{GetUserById(userId).name} - {GetUserById(userId).position_name}";
        ws.Range("B8:C8").Merge();

        var range = ws.Cell("B12").InsertTable(data);
        range.Style.Border.TopBorder = XLBorderStyleValues.Thin;
        range.Style.Border.LeftBorder = XLBorderStyleValues.Thin;
        range.Style.Border.RightBorder = XLBorderStyleValues.Thin;
        range.Style.Border.BottomBorder = XLBorderStyleValues.Thin;

        ws.Row(12).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
        ws.Row(12).Style.Font.Bold = true;

        MemoryStream stream = (MemoryStream)GetStream(wb);

        return File(stream.ToArray(), ""application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"", "yourfilename.xlsx");

這里 Getstream 的代碼:

public Stream GetStream(XLWorkbook excelWorkbook)
        {
            Stream fs = new MemoryStream();
            excelWorkbook.SaveAs(fs);
            fs.Position = 0;
            return fs;
        }

或者,您可以嘗試使用ClosedXML庫:

XLWorkbook workbook = new XLWorkbook();
DataTable table = GetYourTable();
var sheet = workbook.Worksheets.Add(table);

var firstColumn = sheet.Column(1);
firstColumn.InsertColumnsBefore(5);

此代碼通過從數據表中創建一個新的 Excel 工作表來工作,獲取指向工作表中第一列的指針,然后在它之前插入五列 (A - E)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM