加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net 导出excel 中文乱码解决方法

发布时间:2020-12-16 03:55:13 所属栏目:asp.Net 来源:网络整理
导读:完整方法如下: /// summary /// 把DataTable内容导出excel并返回客户端 /// /summary /// param name="dgData"待导出的DataTable/param /// 创 建 人:陈文凯 /// 创建日期:2005年10月08日 /// 修 改 人: ranbolwb 修改导出中文乱码的问题 /// 修改日期:

完整方法如下: /// <summary> /// 把DataTable内容导出excel并返回客户端 /// </summary> /// <param name="dgData">待导出的DataTable</param> /// 创 建 人:陈文凯 /// 创建日期:2005年10月08日 /// 修 改 人: ranbolwb 修改导出中文乱码的问题 /// 修改日期: 2012-05-29 public static void DataTable2Excel(System.Data.DataTable dtData) { System.Web.UI.WebControls.DataGrid dgExport = null; // 当前对话 System.Web.HttpContext curContext = System.Web.HttpContext.Current; // IO用于导出并返回excel文件 System.IO.StringWriter strWriter = null; System.Web.UI.HtmlTextWriter htmlWriter = null; if (dtData != null) { // 设置编码和附件格式 curContext.Response.ContentType = "application/vnd.ms-excel"; curContext.Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312"); curContext.Response.Charset = "gb2312"; // 导出excel文件 strWriter = new System.IO.StringWriter(); htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter); // 为了解决dgData中可能进行了分页的情况,需要重新定义一个无分页的DataGrid dgExport = new System.Web.UI.WebControls.DataGrid(); dgExport.DataSource = dtData.DefaultView; dgExport.AllowPaging = false; dgExport.DataBind(); // 返回客户端 dgExport.RenderControl(htmlWriter); curContext.Response.Clear(); curContext.Response.Write("<meta http-equiv="content-type" content="application/ms-excel; charset=gb2312"/>" + strWriter.ToString()); curContext.Response.End(); } }--------------------- 作者:ranbolwb 来源:CSDN 原文:https://blog.csdn.net/ranbolwb/article/details/7611811 版权声明:本文为博主原创文章,转载请附上博文链接!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读