使用RenderControl方法把GridView控件导出到EXCEL

使用RenderControl方法把GridView控件导出到EXCEL// 把GridView输出到Excel文件       privatevoidExportExcel(GridViewgridView,stringtitle,stringtitle2,stringfileName)       {           intnHideCols=0;           //如果不想输出出某列,将Visible

大家好,又见面了,我是你们的朋友全栈君。

 //  把GridView输出到Excel文件
        private void ExportExcel(GridView gridView, string title, string title2, string fileName)
        {

            int nHideCols = 0;
            //如果不想输出出某列,将Visible设为false即可
            for (int i = 0; i < gridView.Columns.Count; i++)
            {

                if (gridView.Columns[i].HeaderText == “设备状态”)
                {

                    gridView.Columns[i].Visible = false;
                    gridView.Columns[i].ControlStyle.Width = 0;
                    nHideCols = 1;
                    break;
                }
            }
            //设定显示字符集
            Response.Charset = “utf-8”;
            //设定内容字符集
            Response.ContentEncoding = Encoding.GetEncoding(“utf-8”); 

           Asp.net中Response.Charset 与Response.ContentEncoding区别 


            //设定文件名
            Response.AppendHeader(“Content-Disposition”, “attachment;filename=” + HttpUtility.UrlEncode(fileName, Encoding.UTF8).Replace(‘+’, ‘_’).Replace(‘-‘, ‘_’));
            //设定文件类型   也可以是application/ms-word,也可以是text/html(字符集设为gb2312)
            Response.ContentType = “application/ms-excel”;
            this.EnableViewState = false;
            using (StringWriter tw = new StringWriter())
            {

                using (HtmlTextWriter hell = new HtmlTextWriter(tw))
                {

                    gridView.AllowPaging = false;
                    gridView.RenderControl(hell);

                    string s = tw.ToString();
                    s = s.Replace(“\r\n”, “”);
                    int index = s.IndexOf(“<tr”);
                    //可以自定义Excel文件的标题
                    string head = “<tr><td colspan=\”” + (gridView.Columns.Count – nHideCols).ToString() + “\” style=\”text-align: center; height: 42px; font-size: 24px; font-weight: bolder; color: #000000;\”>” + title + “</td></tr>” +
                            “<tr><td colspan=\”” + (gridView.Columns.Count – nHideCols).ToString() + “\” style=\”text-align: center; height: 24px; font-size: 12px; color: #000000;\”>” + title2 + “</td></tr>”;
                    //使用Index来判断是否存在数据,当然也可以用gridView.Rows.Count来判断
                    if (index != -1)
                    {

                        //有数据的
                        s = s.Insert(index, head);
                    }
                    else
                    {

                        //没有数据的时候
                        s = “<table cellspacing=\”0\” cellpadding=\”3\” rules=\”rows\” border=\”1\” id=\”” + gridView.ID + “\” style=\”background-color:White;border-color:#E7E7FF;border-width:1px;border-style:None;border-collapse:collapse;\”>” +
                            head + “</table>”;
                    }
                    Response.Write(s);
                    Response.End();
                }
            }
        }

        //同时vs2005,vs2003会报错“类型“ExGridView”的控件“GridViewMaster”必须放在具有 runat=server 的窗体标记内
        //需要添加下面取消对GridViewMaster 控件验证的方法
        public override void VerifyRenderingInServerForm(Control control)
        {

            if (!control.GetType().Equals(gridView.GetType()))
            {

                base.VerifyRenderingInServerForm(control);
            }
        }

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162030.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 白嫖 IObit 系列软件例如 IObit Uninstaller

    白嫖 IObit 系列软件例如 IObit Uninstaller一、下载version.dllhttps://wws.lanzous.com/iFhkhm0g3qh二、将它复制到安装目录三、看到Pro即成功使用注意:右下角管理注册码别点,否则会闪退,闪退重启程序一样正常使用

    2022年10月20日
    4
  • Java中compareTo()方法比较字符串详解

    Java中compareTo()方法比较字符串详解中心:String是字符串,它的比较用compareTo方法,它从第一位开始比较,如果遇到不同的字符,则马上返回这两个字符的ascii值差值.返回值是int类型1.当两个比较的字符串是英文且长度不等时,1)长度短的与长度长的字符一样,则返回的结果是两个长度相减的值a=”hello”;b=”hell”;num=1;或者a=”h”;b=”hello”;num=4;2)…

    2022年7月13日
    17
  • 发送激活邮件「建议收藏」

    发送激活邮件「建议收藏」发送激活邮件

    2022年4月24日
    47
  • JMM内存模型

    JMM内存模型Java内存模型即JavaMemoryModel,简称JMM。JMM定义了Java虚拟机(JVM)在计算机内存(RAM)中的工作方式。JVM是整个计算机虚拟模型,所以JMM是隶属于JVM的。如果我们要想深入了解Java并发编程,就要先理解好Java内存模型。Java内存模型定义了多线程之间共享变量的可见性以及如何在需要的时候对共享变量进行同步。原始的Java内存模型效率并不是很理想,

    2022年6月1日
    49
  • WAP网站开发的要点

    WAP网站开发的要点开发维护移动的 WAP 网站也有一段时间了 总结一下我认为 WAP 网站的要点 1 速度永远是第一位的 手机上网本来速度就慢 没办法只有在服务器端提高速度 采取了一些措施 如数据都是放在缓存中 对数据库中数据的更新都是有进程来定时更新有变更的表 对于一些精巧的技术 如反射 都不能使用 2 考虑到终端的多样性 手机访问的终端显示屏幕五花八门 有的可以显示 10 行 有的只能显示 4 行 有的支持彩色 有的连

    2025年8月14日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号