码迷,mamicode.com
首页 > 编程语言 > 详细

导出到Excel并且取消默认的科学计算法

时间:2016-10-27 10:00:38      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:header   position   share   buffer   eve   div   导出excel   cal   out   

 导出Excel的代码很多,其中这种最简单:

 protected void btnDCAll_Click(object sender, EventArgs e)
        {
            string DataString = DateTime.Now.ToString("yyyyMMddHHmmss");//已当前年月日时分秒做为文件名
            Response.Clear();
            Response.Buffer = true;
            Response.Charset = "GB2312";
            Response.AppendHeader("Content-Disposition", "attachment;filename=" + DataString + ".xls");
                       Response.ContentEncoding = System.Text.Encoding.UTF7;
            Response.ContentType = "application/ms-excel";//设置输出文件类型为excel文件。 
            System.IO.StringWriter oStringWriter = new System.IO.StringWriter();
            System.Web.UI.HtmlTextWriter oHtmlTextWriter = new System.Web.UI.HtmlTextWriter(oStringWriter);
            this.GridViewAll.RenderControl(oHtmlTextWriter);//GridViewAll是GridView的名字,也可以放到一个Table中或是DataTable中
            Response.Output.Write(oStringWriter.ToString());
            Response.Flush();
            Response.End();
        }

 

 public override void VerifyRenderingInServerForm(Control control)
        {
        }

导出之后,如果数据比较多,会遇到科学计数法问题

解决的方法是:

  protected void GridViewAll_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            if (e.Row.RowType == DataControlRowType.DataRow)
            {
                    e.Row.Cells[0].Attributes.Add("style", "vnd.ms-excel.numberformat:@");//你所需要处理的列

                    //或所有的列

                     for (int i = 0; i < e.Row.Cells.Count; i++)
                     {
                           e.Row.Cells[i].Attributes.Add("style", "vnd.ms-excel.numberformat:@");
                     }

            }

       }

 
 

导出到Excel并且取消默认的科学计算法

标签:header   position   share   buffer   eve   div   导出excel   cal   out   

原文地址:http://www.cnblogs.com/future/p/6002729.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!