ASP.NET使用GridView导出Excel实现方法

 更新时间:2014年11月25日 09:10:32   投稿:shichen2014  
这篇文章主要介绍了ASP.NET使用GridView导出Excel实现方法,是asp.net操作office文件的一个典型应用,代码中备有较为详尽的注释便于读者理解,需要的朋友可以参考下

本文实例讲述了ASP.NET使用GridView导出Excel实现方法。分享给大家供大家参考。具体实现方法如下:

复制代码 代码如下:
/// <summary> 
/// 将DataTable数据导出到EXCEL,调用该方法后自动返回可下载的文件流 
/// </summary> 
/// <param name="dtData">要导出的数据源</param> 
public static void DataTable1Excel(System.Data.DataTable dtData) 

        System.Web.UI.WebControls.GridView gvExport = null; 
        // 当前对话 
        System.Web.HttpContext curContext = System.Web.HttpContext.Current; 
        // IO用于导出并返回excel文件 
        System.IO.StringWriter strWriter = null; 
        System.Web.UI.HtmlTextWriter htmlWriter = null; 
 
        if (dtData != null) 
        { 
            // 设置编码和附件格式 
            curContext.Response.ContentType = "application/vnd.ms-excel"; 
            curContext.Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312"); 
            curContext.Response.Charset = "utf-8"; 
 
            // 导出excel文件 
            strWriter = new System.IO.StringWriter(); 
            htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter); 
            // 为了解决gvData中可能进行了分页的情况,需要重新定义一个无分页的GridView 
            gvExport = new System.Web.UI.WebControls.GridView(); 
            gvExport.DataSource = dtData.DefaultView; 
            gvExport.AllowPaging = false; 
            gvExport.DataBind(); 
 
            // 返回客户端 
            gvExport.RenderControl(htmlWriter); 
            curContext.Response.Write("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\" />" + strWriter.ToString()); 
            curContext.Response.End(); 
        } 

 
/// <summary> 
/// 直接输出Excel 
/// </summary> 
/// <param name="dtData"></param> 
public static void DataTable2Excel(System.Data.DataTable dtData) 

          System.Web.UI.WebControls.DataGrid dgExport = null; 
      // 当前对话 
      System.Web.HttpContext curContext = System.Web.HttpContext.Current; 
      // IO用于导出并返回excel文件 
      System.IO.StringWriter strWriter = null; 
      System.Web.UI.HtmlTextWriter htmlWriter = null; 
 
      if (dtData != null) 
      { 
        // 设置编码和附件格式 
        curContext.Response.ContentType = "application/vnd.ms-excel"; 
        curContext.Response.ContentEncoding =System.Text.Encoding.UTF8; 
        curContext.Response.Charset = ""; 
                 
        // 导出excel文件 
        strWriter = new System.IO.StringWriter(); 
        htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter); 
 
        // 为了解决dgData中可能进行了分页的情况,需要重新定义一个无分页的DataGrid 
        dgExport = new System.Web.UI.WebControls.DataGrid();          
        dgExport.DataSource = dtData.DefaultView; 
        dgExport.AllowPaging = false; 
        dgExport.DataBind(); 
 
        // 返回客户端 
        dgExport.RenderControl(htmlWriter);   
        curContext.Response.Write(strWriter.ToString()); 
        curContext.Response.End(); 
      } 
}

希望本文所述对大家的asp.net程序设计有所帮助。

相关文章

  • 总结Visual Studio下ASP.NET模板化控件中的数据绑定

    总结Visual Studio下ASP.NET模板化控件中的数据绑定

    .NET框架中提供了很多数据绑定的组件,这里我们就来总结Visual Studio下ASP.NET模板化控件中的数据绑定,需要的朋友可以参考下
    2016-06-06
  • ASP.NET Core 数据保护(Data Protection 集群场景)下篇

    ASP.NET Core 数据保护(Data Protection 集群场景)下篇

    这篇文章主要为大家再一次介绍了ASP.NET Core 数据保护(Data Protection),具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 使用Hangfire+.NET 6实现定时任务管理(推荐)

    使用Hangfire+.NET 6实现定时任务管理(推荐)

    这篇文章主要介绍了使用Hangfire+.NET 6实现定时任务管理,通过引入Hangfire相关的Nuget包并对Hangfire进行服务配置,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • ASP.NET Core 1.0 部署 HTTPS(.NET Core 1.0)

    ASP.NET Core 1.0 部署 HTTPS(.NET Core 1.0)

    这篇文章主要为大家详细介绍了ASP.NET Core 1.0 部署 HTTPS(.NET Core 1.0),感兴趣的小伙伴们可以参考一下
    2016-07-07
  • .NET Core 中实现异步编程并提升性能的操作方法

    .NET Core 中实现异步编程并提升性能的操作方法

    在.net core中异步编程主要通过async和await关键字来实现,结合Task类进行异步操作的管理,这篇文章主要介绍了.NET Core 中实现异步编程并提升性能的操作方法,需要的朋友可以参考下
    2024-12-12
  • ASP.NET MVC下拉框联动实例解析

    ASP.NET MVC下拉框联动实例解析

    这篇文章主要为大家详细介绍了ASP.NET MVC下拉框联动实现方法,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • ASP.NET用户注册实战(第11节)

    ASP.NET用户注册实战(第11节)

    这篇文章主要介绍了ASP.NET用户注册实战,巩固前10小节所学的全部知识,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-08-08
  • 正则一则 将金额转换成人民币大写的代码

    正则一则 将金额转换成人民币大写的代码

    首先声明,这个正则不是我写的,来源于互联网,发现好用,稍作更改,贴上分享
    2012-01-01
  • asp.net 事件与委托分析

    asp.net 事件与委托分析

    delegate是C#中的一种类型,它实际上是一个能够持有对某个方法的引用的类。与其它的类不同,delegate类能够拥有一个签名(signature),并且它只能持有与它的签名相匹配的方法的引用。
    2009-02-02
  • asp.net Repeater分页实例(PageDataSource的使用)

    asp.net Repeater分页实例(PageDataSource的使用)

    Asp.net提供了三个功能强大的列表控件:DataGrid、DataList和Repeater控件,但其中只有DataGrid控件提供分页功能。相对DataGrid,DataList和Repeater控件具有更高的样式自定义性,所以很多时候我们喜欢使用DataList或Repeater控件来显示数据
    2013-04-04

最新评论