现在的位置: 主页 > 商讯 > 文章列表

Asp.net网页中DataGridView数据导出到Excel

作者:厦工楚胜(湖北)专用汽车制造有限公司 来源:www.szzq168.com 发布时间:2017-09-02 11:48:18
 

Asp.net网页中DataGridView数据导出到Excel

一、从DataGridView中直接导出数据到Excel文件

经过上网找资料,终于找到一种可以直接将GridView中数据导出到Excel文件的方法,归纳方法如下:

1、 注:其中的字符集格式若改为“GB2312”,专题,导出的部分数据可能为乱码;

导出之前需要关闭分页部分,若分页只导出首页的数据;

///

/// 下载数据

///

///文件类型

///Excel表名

private void Excel(string FileType, string FileName)

{

try

{

Response.Clear();

Response.Buffer = true;

Response.Charset = "utf-8";

//返回与指定代码页关联的数据

Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");

//attachment表示作为附件下载,filename指定输出文件名称

Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString());

//指定文件类型

Response.ContentType = FileType;

this.EnableViewState = false;

System.Globalization.CultureInfo myCItrad = new System.Globalization.CultureInfo("ZH-CN", true);

//定义一输入流

StringWriter tw = new StringWriter(myCItrad);

HtmlTextWriter hw = new HtmlTextWriter(tw);

this.gvJstList.RenderControl(hw);

Response.Write(tw.ToString());

Response.End();

}

catch (Exception err)

{

ScriptManager.RegisterStartupScript(this, this.GetType(), "js", "showInfo('ctl00_Contentplaceholder2_ValidationSummary1',1,'发生错误:" + err.Message.Replace("\r\n", "\\r\\n").Replace("'", "‘") + "')", true);

return;

}

}

如上代码如果处理一般的GridView导出应该是没有问题的,但是如果GridView的AutoGenerateDeleteButton,AutoGenerateEditButton,AutoGenerateSelectButton有的设置为True了,或者GridView中有HyperLinkField类型的字段,那么就会抛出形如“类型“GridView”的控件“XXXX”必须放在具有 runat=server 的窗体标记内。”的异常!

那么他的解决方案是:对WebForm窗体的VerifyRenderingInServerForm方法进行Override!

代码如下:

public override void VerifyRenderingInServerForm(Control control)

{

//OverRide 为了使导出成Excel可行!

}

2、/*如导出的表中有某些列为编号、身份证号之类的纯数字字符串,如不进行处理,则导出的数据会默认为数字,例如原字符串"0010"则会变为数字10,字符串"1245787888"则会变为科学计数法1.236+E9,这样便达不到我们想要的结果,专题,所以需要在导出前对相应列添加格式化的数据类型,以下为格式化为字符串型*/

在上面的代码中添加以下代码:

foreach (GridViewRow dg in this.gridview1.Rows)

  {

  dg.Cells[0].Attributes.Add("style", "vnd.ms-excel.numberformat: @;");

  dg.Cells[5].Attributes.Add("style", "vnd.ms-excel.numberformat: @;");

  dg.Cells[6].Attributes.Add("style", "vnd.ms-excel.numberformat: @;");

  dg.Cells[8].Attributes.Add("style", "vnd.ms-excel.numberformat: @;");

  }

或者是在DataGridView事件RowDataBound中添加以下代码:

if(e.Row.RowType == DataControlRowType.DataRow )

{

e.Row.Cells[3].Attributes.Add("style", "vnd.ms-excel.numberformat:@");

e.Row.Cells[4].Attributes.Add("style", "vnd.ms-excel.numberformat:@");

}

企业建站2800元起,携手武汉肥猫科技,做一个有见地的颜值派!更多优惠请戳:宜昌SEO http://yichang.4567w.com

  • 上一篇:谈武汉企业网站建设:品牌文化价值才是网站建设的核心
  • 下一篇:最后一页