ASP.NET 一键导出数据






4.82/5 (13投票s)
ASP.NET 一键导出数据,GridView 导出到 DOC – GridView 导出到 Excel – GridView 导出到 PDF
引言
在这篇文章中,我将展示将数据导出到其他文档软件的能力。在其他软件中,您可以轻松完成许多工作。为了排序、搜索和安全目的,您可能不希望以 Excel 和 Doc 格式提供数据,因此您可以使用导出 GridView
到 PDF。
在这篇文章中,您可以阅读一些将数据导出到文档和 PDF 文件的技巧。
在 .aspx 页面中
在 .aspx 页面中,首先添加控件,TextBox
和 Button
以及 Gridview
。首先,我在文本框中编写查询,然后单击“GO”按钮,填充一个 Gridview
。然后我使用三个按钮导出到 Word、导出到 Excel、导出到 PDF。
导出到 Word
在导出到 Word 时,将此代码写入 btnexport
的 Click
事件中。
Response.AddHeader("content-disposition", "attachment;filename=Export.doc");
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.ContentType = "application/vnd.word";
System.IO.StringWriter stringWrite = new System.IO.StringWriter();
System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);
// Create a form to contain the grid
HtmlForm frm = new HtmlForm();
gv.Parent.Controls.Add(frm);
frm.Attributes["runat"] = "server";
frm.Controls.Add(gv);
frm.RenderControl(htmlWrite);
//GridView1.RenderControl(htw);
Response.Write(stringWrite.ToString());
Response.End();
单击后,将打开一个“另存为”对话框
导出到 Excel
在导出到 Excel 时,将此代码写入 btnexporttoExcel Click
事件中。
string attachment = "attachment; filename=Export.xls";
Response.ClearContent();
Response.AddHeader("content-disposition", attachment);
Response.ContentType = "application/ms-excel";
StringWriter sw = new StringWriter();
HtmlTextWriter htw = new HtmlTextWriter(sw);
// Create a form to contain the grid
HtmlForm frm = new HtmlForm();
gv.Parent.Controls.Add(frm);
frm.Attributes["runat"] = "server";
frm.Controls.Add(gv);
frm.RenderControl(htw);
//GridView1.RenderControl(htw);
Response.Write(sw.ToString());
Response.End();
单击后,将打开一个“另存为”对话框。
导出到 PDF
您想将 Gridview
导出到 PDF,因此首先添加 itextsharp.dll。
链接: http://sourceforge.net/projects/itextsharp/
然后添加一些命名空间
using iTextSharp.text;
using iTextSharp.text.pdf;
using iTextSharp.text.html;
using iTextSharp.text.html.simpleparser;
在导出到 PDF 时,将此代码写入 btnexporttoPdf Click
事件中。
Response.ContentType = "application/pdf";
Response.AddHeader("content-disposition", "attachment;filename=Export.pdf");
Response.Cache.SetCacheability(HttpCacheability.NoCache);
StringWriter sw = new StringWriter();
HtmlTextWriter hw = new HtmlTextWriter(sw);
HtmlForm frm = new HtmlForm();
gv.Parent.Controls.Add(frm);
frm.Attributes["runat"] = "server";
frm.Controls.Add(gv);
frm.RenderControl(hw);
StringReader sr = new StringReader(sw.ToString());
Document pdfDoc = new Document(PageSize.A4, 10f, 10f, 10f, 0f);
HTMLWorker htmlparser = new HTMLWorker(pdfDoc);
PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
pdfDoc.Open();
htmlparser.Parse(sr);
pdfDoc.Close();
Response.Write(pdfDoc);
Response.End();
单击后,将打开一个“另存为”对话框