【发布时间】:2016-05-22 23:13:58
【问题描述】:
我正在开发一个 ASP.NET 4.5 Webform,并且我有一个 Gridview(具有自定义 TemplateField 并从 sqlDataSource 获取数据)
我有这个事件将 gridview 内容导出到 excel 工作表,它的工作很好,除了创建的文件在用户打开它时发出警告(我理解这是因为创建的文件不是实际的excel文件):
"您尝试打开的文件的格式不同于 由文件扩展名指定”
protected void btnExport_Excel_Click(object sender, EventArgs e)
{
try
{
Response.Clear();
Response.Buffer = true;
Response.AddHeader("content-disposition", "attachment;filename=GV.xls");
Response.Charset = "";
Response.ContentType = "application/ms-excel";
//Response.ContentType = "application/text";
Response.ContentEncoding = System.Text.Encoding.Unicode;
Response.BinaryWrite(System.Text.Encoding.Unicode.GetPreamble());
using (StringWriter sw = new StringWriter())
{
HtmlTextWriter hw = new HtmlTextWriter(sw);
//To Export all pages
GridView4.AllowPaging = false;
GridView4.AllowSorting = false;
GridView4.ShowFooter = false;
GridView4.DataBind();
//this.BindGrid();
GridView4.HeaderRow.BackColor = Color.White;
foreach (TableCell cell in GridView4.HeaderRow.Cells)
{
cell.BackColor = GridView4.HeaderStyle.BackColor;
}
foreach (GridViewRow row in GridView4.Rows)
{
row.BackColor = Color.White;
foreach (TableCell cell in row.Cells)
{
if (row.RowIndex % 2 == 0)
{
cell.BackColor = GridView4.AlternatingRowStyle.BackColor;
}
else
{
cell.BackColor = GridView4.RowStyle.BackColor;
}
cell.CssClass = "textmode";
}
}
GridView4.RenderControl(hw);
//style to format numbers to string
string style = @"<style> .textmode { } </style>";
Response.Write(style);
Response.Output.Write(sw.ToString());
Response.Flush();
Response.End();
}
//Display message
InfoPanel.Visible = true;
InfoPanel.CssClass = "panel panel-success";
lblMessage.CssClass = "text text-sucess bold";
lblMessage.Text = "File has been exported!";
}
catch (Exception ex)
{
//Display message
InfoPanel.Visible = true;
lblMessage.Text = "<b>An error has occurred. Please try again later!</b></br>" + ex.Message;
lblMessage.CssClass = "text text-danger bold";
InfoPanel.CssClass = "panel panel-danger";
panelResult.Visible = false;
}
}
Excel .xls 文件中的结果很好(除了标题列之外没有样式,没有页脚,就像 Gridview 上显示的一样):
我正在寻找另一种方法来避免这个警告,所以我看到人们喜欢使用
ClosedXML,所以我将上面的那个事件替换为这个事件:
protected void ExportExcel(object sender, EventArgs e)
{
DataTable dt = new DataTable("GridView_Data");
foreach(TableCell cell in GridView4.HeaderRow.Cells)
{
dt.Columns.Add(cell.Text);
}
foreach (GridViewRow row in GridView4.Rows)
{
dt.Rows.Add();
for (int i=0; i<row.Cells.Count; i++)
{
dt.Rows[dt.Rows.Count - 1][i] = row.Cells[i].Text;
}
}
using (XLWorkbook wb = new XLWorkbook())
{
wb.Worksheets.Add(dt);
Response.Clear();
Response.Buffer = true;
Response.Charset = "";
Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
Response.AddHeader("content-disposition", "attachment;filename=GV.xlsx");
using (MemoryStream MyMemoryStream = new MemoryStream())
{
wb.SaveAs(MyMemoryStream);
MyMemoryStream.WriteTo(Response.OutputStream);
Response.Flush();
Response.End();
}
}
}
结果很糟糕(唯一的好处是导出的文件是真正的 2007+ Excel 工作表,因此没有警告):
如何使用 closedXML 获得上述“好”结果?
【问题讨论】:
-
在将数据表插入工作表之前,您是否检查过它?在将数据添加到 DataTable 之后,您可能需要先调用
dt.AcceptChanges();。 -
只是把它放进去,结果还是一样?
-
如果我理解正确,您对第二个 excel (closedXML) 感到满意,但数据未显示?
-
是的,我想使用 ClosedXML 导出一个真正的 excel 文件,但是没有显示标题和数据,代码有问题。
-
您以错误的方式处理此问题,为什么要解析标头等。您可以使用 ClosedXML 用更少的代码完成此操作我将发布一个您可以遵循的工作示例。我使用ClosedXML 每日零问题。
标签: c# asp.net gridview export-to-excel closedxml