将数据从数据表插入到 Excel 工作表中
本文关键字:Excel 工作 插入 数据 数据表 | 更新日期: 2023-09-27 18:33:55
我正在将数据从数据库提取到DataTable
中,并通过将其绑定到Repeater
控件来显示它。现在我需要将相同的数据复制到 excel 电子表格中。我怎样才能使用相同的DataTable
来填写电子表格。请指教。
我建议创建一个真正的 excel 文件而不是 html 表(许多人都会这样做)。因此,我可以热烈推荐EPPlus
(LGPL许可证)。
那就简单了。假设您有一个按钮BtnExportExcel
:
protected void BtnExcelExport_Click(object sender, System.Web.UI.ImageClickEventArgs e)
{
try {
var pck = new OfficeOpenXml.ExcelPackage();
var ws = pck.Workbook.Worksheets.Add("Name of the Worksheet");
// get your DataTable
var tbl = GetDataTable();
ws.Cells["A1"].LoadFromDataTable(tbl, true, OfficeOpenXml.Table.TableStyles.Medium6);
foreach (DataColumn col in tbl.Columns) {
if (col.DataType == typeof(System.DateTime)) {
var colNumber = col.Ordinal + 1;
var range = ws.Cells[1, colNumber, tbl.Rows.Count, colNumber];
// apply the correct date format, here for germany
range.Style.Numberformat.Format = "dd.MM.yyyy";
}
}
var dataRange = ws.Cells[ws.Dimension.Address.ToString()];
dataRange.AutoFitColumns();
Response.Clear();
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AddHeader("content-disposition", "attachment; filename=NameOfExcelFile.xlsx");
Response.BinaryWrite(pck.GetAsByteArray());
} catch (Exception ex) {
// log exception
throw;
}
Response.End();
}
您可以创建.csv文件。 这既快速又简单,并且可以在 excel 中打开它。
这篇文章与您的帖子有关:
将数据表转换为 CSV 流