导出excel

public static class Excel
    {
        /// <summary>
        /// 将dataset里的数据导出为Excel.
        /// </summary>
        /// <param name="fileName">导出时保存的文件名.</param>
        /// <param name="page">页对象.</param>
        /// <param name="dataset">数据集.</param>
        public static void ExportExcel(string fileName, Page page, DataSet dataset)
        {
            try
            {
                page.Response.Clear();
                page.Response.Buffer = false;
                page.Response.Charset = "GB2312";
                page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");
                page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//设置输出流为简体中文
                page.Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。 
                // 指定返回的是一个不能被客户端读取的流,必须被下载 
                page.Response.ContentType = "application/ms-excel";
                page.EnableViewState = false;
                page.Response.BufferOutput = false;
                page.Response.Write("<meta http-equiv=Content-Type content=text/html;charset=gb2312>");
                page.Response.Write(ExportTable(dataset));
                page.Response.Flush();
                page.Response.End();
            }
            catch (System.Exception)
            {
            }
        }
        /// <summary>
        /// 将DataSet信息输出为string
        /// </summary>
        /// <param name="dataset">DataSet信息</param>
        /// <returns>string格式的信息</returns>
        public static string ExportTable(DataSet dataset)
        {
            if (dataset == null)
                return string.Empty;
            StringBuilder strBuilder = new StringBuilder();
            foreach (DataTable table in dataset.Tables)
            {
                strBuilder.AppendLine("<table border=1 cellspacing=0 cellpadding=5 rules=all >");
                //输出表头.
                strBuilder.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
                foreach (DataColumn headColumn in table.Columns)
                {
                    strBuilder.AppendLine("<td>" + headColumn.ColumnName + "</td>");
                }
                strBuilder.AppendLine("</tr>");
                //输出数据.
                foreach (DataRow row in table.Rows)
                {
                    strBuilder.AppendLine("<tr>");
                    foreach (DataColumn dataColumn in table.Columns)
                    {
                        strBuilder.AppendLine("<td style=\"mso-number-format:'\\@';\">");
                        strBuilder.AppendLine(row[dataColumn].ToString());
                        strBuilder.AppendLine("</td>");
                    }
                    strBuilder.AppendLine("</tr>");
                }
                strBuilder.AppendLine("</table>");
            }
            return strBuilder.ToString();
        }



        /// <summary>
        /// 将dataset里的数据导出为Excel.
        /// </summary>
        /// <param name="fileName">导出时保存的文件名.</param>
        /// <param name="page">页对象.</param>
        /// <param name="dataset">数据集.</param>
        public static void ExportExcel(string fileName, Page page, DataTable datatable)
        {
            try
            {
                page.Response.Clear();
                page.Response.Buffer = false;
                page.Response.Charset = "GB2312";
                page.Response.AppendHeader("Content-Disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8) + ".xls");
                page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//设置输出流为简体中文;
                page.Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。 
                // 指定返回的是一个不能被客户端读取的流,必须被下载 
                page.Response.ContentType = "application/ms-excel";
                page.EnableViewState = false;
                page.Response.BufferOutput = false;
                page.Response.Write("<meta http-equiv=Content-Type content=text/html;charset=gb2312>");
                page.Response.Write(ExportTable(datatable));
                page.Response.Flush();
                page.Response.End();
            }
            catch (System.Exception)
            {
            }
        }
        /// <summary>
        /// 将DataSet信息输出为string
        /// </summary>
        /// <param name="dataset">DataSet信息</param>
        /// <returns>string格式的信息</returns>
        public static string ExportTable(DataTable dataTable)
        {
            StringBuilder strBuilder = new StringBuilder();
            strBuilder.AppendLine("<table border=1 cellspacing=0 cellpadding=5 rules=all >");
            //输出表头.
            strBuilder.AppendLine("<tr style=\"font-weight: bold; white-space: nowrap;\">");
            foreach (DataColumn headColumn in dataTable.Columns)
            {
                strBuilder.AppendLine("<td>" + headColumn.ColumnName + "</td>");
            }
            strBuilder.AppendLine("</tr>");
            //输出数据.
            foreach (DataRow row in dataTable.Rows)
            {
                strBuilder.AppendLine("<tr>");
                foreach (DataColumn dataColumn in dataTable.Columns)
                {
                    strBuilder.AppendLine("<td style=\"mso-number-format:'\\@';\">");
                    strBuilder.AppendLine(row[dataColumn].ToString());
                    strBuilder.AppendLine("</td>");
                }
                strBuilder.AppendLine("</tr>");
            }
            strBuilder.AppendLine("</table>");

            return strBuilder.ToString();
        }
    }

转载于:https://www.cnblogs.com/gotolovo/archive/2012/04/13/2445210.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值