65.9K
CodeProject 正在变化。 阅读更多。
Home

ASP.NET 一键导出数据

starIconstarIconstarIconstarIcon
emptyStarIcon
starIcon

4.82/5 (13投票s)

2011 年 5 月 22 日

CPOL

1分钟阅读

viewsIcon

127256

ASP.NET 一键导出数据,GridView 导出到 DOC – GridView 导出到 Excel – GridView 导出到 PDF

引言

在这篇文章中,我将展示将数据导出到其他文档软件的能力。在其他软件中,您可以轻松完成许多工作。为了排序、搜索和安全目的,您可能不希望以 Excel 和 Doc 格式提供数据,因此您可以使用导出 GridView 到 PDF。

在这篇文章中,您可以阅读一些将数据导出到文档和 PDF 文件的技巧。

在 .aspx 页面中

.aspx 页面中,首先添加控件,TextBoxButton 以及 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();

单击后,将打开一个“另存为”对话框

© . All rights reserved.