当前位置:K88软件开发文章中心办公应用办公应用18 → 文章内容

ASP.NET中将数据输出到Excel

减小字体 增大字体 作者:华军  来源:华军资讯  发布时间:2019-3-5 0:39:36

近来,在开发ISO文件管理系统的时候,曾经遇到过要将ASPX直接输出到EXCEL的需求,现将经验所得与大家分享。其实,利用ASP.NET输出指定内容的WORD、EXCEL、TXT、HTM等类型的文档很容易的。主要分为三步来完成。一、定义文档类型、字符编码Response.Clear();Response.Buffer=true;Response.Charset="utf-8";//下面这行很重要,attachment参数表示作为附件下载,您可以改成online在线打开//filename=FileFlow.xls指定输出文件的名称,注意其扩展名和指定文件类型相符,可以为:.doc||.xls||.txt||.htmResponse.AppendHeader("Content-Disposition","attachment;filename=FileFlow.xls");Response.ContentEncoding=System.Text.Encoding.GetEncoding("utf-8");//Response.ContentType指定文件类型可以为application/ms-excel||application/ms-word||application/ms-txt||application/ms-html||或其他浏览器可直接支持文档Response.ContentType="application/ms-excel";this.EnableViewState=false;二、定义一个输入流System.IO.StringWriteroStringWriter=newSystem.IO.StringWriter();System.Web.UI.HtmlTextWriteroHtmlTextWriter=newSystem.Web.UI.HtmlTextWriter(oStringWriter);三、将目标数据绑定到输入流输出this.RenderControl(oHtmlTextWriter);//this表示输出本页,你也可以绑定datagrid,或其他支持obj.RenderControl()属性的控件Response.Write(oStringWriter.ToString());Response.End();总结:本例程在MicrosoftVisualStudio.NET2003平台下测试通过,适用于C#和VB,当采用VB的时候将this关键字改成me。

ASP.NET中将数据输出到Excel