zoukankan      html  css  js  c++  java
  • 将ASP.NET页面内的数据导出到Excel 或 Word中

    在以下按钮单击事件中实现:
    private void btnMIME_Click(object sender, System.EventArgs e)
    {
    dgShow.AllowPaging = false;
     BindData(); 

      Response.ContentType = "application/vnd.ms-excel";
     Response.AddHeader("Content-Disposition", "inline;filename="
       +   HttpUtility.UrlEncode("下载文件.xls",Encoding.UTF8   )   );  
     

     //如果输出为Word,修改为以下代码
     //Response.ContentType = "application/ms-word"
     //Response.AddHeader("Content-Disposition", "inline;filename=test.doc")
     StringBuilder sb=new StringBuilder();
     System.IO.StringWriter sw = new System.IO.StringWriter(sb);
     System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter(sw);
     sb.Append("<html><body>");
     dgShow.RenderControl(hw);
     sb.Append("</body></html>");
     Response.Write(sb.ToString());
     Response.End();
    dgShow.AllowPaging = true;
    BindData(); 

    }
    注:1.若DataGrid中有按钮列,则在导出前应先将其隐藏.
        2.若DataGrid有分页,而又要打印所有数据的话就应先取消分页.

    2006年7月19日-补充:
    若为VS.NET2005中的数据绑定新控件GridView,以上代码会提示异常错误,经网上搜索,解决方案如下:

    1、在导出界面中重载
        public override void VerifyRenderingInServerForm(Control control)
        {
            //base.VerifyRenderingInServerForm(control);
        }
    2、
    web.config中修改<pages enableEventValidation ="false" ></pages>

    <%@ Page Language="C#" EnableEventValidation = "false" AutoEventWireup="true"

     CodeFile="ExportGridView.aspx.cs" Inherits="ExportGridView" %>

  • 相关阅读:
    绘制矩形
    绘制线条
    画直线
    画弧线
    绘制贝塞尔曲线
    我关注的一些博客或资源链接
    vim必记指令
    mac下使用vim gcc/g++ 编译cpp(c++)文件并运行
    机器学习算法中如何选取超参数:学习速率、正则项系数、minibatch size
    正则化方法:L1和L2 regularization、数据集扩增、dropout
  • 原文地址:https://www.cnblogs.com/pyt5208/p/447048.html
Copyright © 2011-2022 走看看