http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 4380|回复: 6

[Asp.Net] asp.net导出Grid的数据(全部)到Excel

[复制链接]
发表于 2018-11-26 18:20:23 | 显示全部楼层 |阅读模式
导出Grid的数据(全部)到Excel


[C#] 纯文本查看 复制代码
        /// <summary>
        /// 导出Grid的数据(全部)到Excel
        /// 字段全部为BoundField类型时可用
        /// 要是字段为TemplateField模板型时就取不到数据
        /// </summary>
        /// <param name="grid">grid的ID</param>
        /// <param name="dt">数据源</param>
        /// <param name="excelFileName">要导出Excel的文件名</param>
        public static void OutputExcel(GridView grid, DataTable dt, string excelFileName)
        {
            Page page = (Page)HttpContext.Current.Handler;
            page.Response.Clear();
            string fileName = System.Web.HttpUtility.UrlEncode(System.Text.Encoding.UTF8.GetBytes(excelFileName));
            page.Response.AddHeader("Content-Disposition", "attachment:filename=" + fileName + ".xls");
            page.Response.ContentType = "application/vnd.ms-excel";
            page.Response.Charset = "utf-8";

            StringBuilder s = new StringBuilder();
            s.Append("<HTML><HEAD><TITLE>" + fileName + "</TITLE><META http-equiv=\"Content-Type\" content=\"text/html; charset=utf-8\"></head><body>");

            int count = grid.Columns.Count;

            s.Append("<table border=1>");
            s.AppendLine("<tr>");
            for (int i = 0; i < count; i++)
            {

                if (grid.Columns.GetType() == typeof(BoundField))
[i]                    s.Append("<td>" + grid.Columns.HeaderText + "</td>");

                //s.Append("<td>" + grid.Columns.HeaderText + "</td>");

            }
            s.Append("</tr>");

            foreach (DataRow dr in dt.Rows)
            {
                s.AppendLine("<tr>");
                for (int n = 0; n < count; n++)
                {
                    if (grid.Columns[n].Visible && grid.Columns[n].GetType() == typeof(BoundField))
                        s.Append("<td>" + dr[((BoundField)grid.Columns[n]).DataField].ToString() + "</td>");

                }
                s.AppendLine("</tr>");
            }

            s.Append("</table>");
            s.Append("</body></html>");

            page.Response.BinaryWrite(System.Text.Encoding.GetEncoding("utf-8").GetBytes(s.ToString()));
            page.Response.End();
        }




其实这个是一个比较简单的方法,而且百度上也会有很多,但是我这个方法的好处就是我一直在用,而且解决了不少Bug
贴出来,有用的拿 去



1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
 楼主| 发表于 2018-11-26 18:21:49 | 显示全部楼层
以前写过一个通用的
C#导入Excel|读取Excel方法总结
http://www.sufeinet.com/thread-8-1-1.html
(出处: 苏飞论坛)

 楼主| 发表于 2018-11-26 18:22:35 | 显示全部楼层
C#将数据导出到Excel的各种方法汇总
http://www.sufeinet.com/thread-4-1-1.html
(出处: 苏飞论坛)
发表于 2018-11-26 18:23:11 | 显示全部楼层
真是难得给力的帖子啊。
发表于 2018-11-27 14:13:05 | 显示全部楼层
我只是路过打酱油的。
发表于 2018-11-27 14:15:03 | 显示全部楼层
帖子不错, 实力贴, 支持ing
发表于 2018-12-16 22:22:02 | 显示全部楼层
支持一下
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-11-22 02:53

© 2014-2021

快速回复 返回顶部 返回列表