C# DataTable导出EXCEL后身份证等信息显示乱码解决
来源:互联网 发布:自作头像软件 编辑:程序博客网 时间:2024/04/29 10:53
在DataTable导出EXCEL后发现有些格式显示有问题,比如身份证号码等大于11位的数字显示为科学计数法、13681-1等 带中划线的两段数字显示为日期格式等。
处理方法如下:
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.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(dgExport_ItemDataBound); 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(); } } protected static void dgExport_ItemDataBound(object sender, DataGridItemEventArgs e) { if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem) { foreach (TableCell cell in e.Item.Cells) { if (Regex.IsMatch(cell.Text.Trim(), @"^\d{12,}$") || Regex.IsMatch(cell.Text.Trim(), @"^\d+[-]\d+$")) { cell.Attributes.Add("style", "vnd.ms-excel.numberformat:@"); } } } }
在DataGrid的行绑定事件给单元格加上样式就可以了。
- C# DataTable导出EXCEL后身份证等信息显示乱码解决
- 导出Excel文档 解决导出Excel文档显示乱码 在C#桌面程序导出Excel文档
- C# DataTable导出Excel
- C#导出EXCEL显示乱码的问题
- C#导出EXCEL(DataTable导出EXCEL)
- C#导出EXCEL(DataTable导出EXCEL)
- C#导出EXCEL(DataTable导出EXCEL)
- C#导出EXCEL(DataTable导出EXCEL)
- C#导出EXCEL(DataTable导出EXCEL)
- C# datatable 导出EXCEL 数据
- C# winform中导出数组等信息到excel
- Excel | mysql mysql中身份证(多位数字)导出到cvs后显示问题
- JSP导出Excel表格 文件名+内容乱码解决+网格显示
- 将DataTable中的数据导出Excel(解决了在火狐中出现乱码情况)
- C# DataTable 导出 Excel 进阶 多行表头、合并单元格、中文文件名乱码
- Jquery datatable 导出乱码 已解决
- c# web datatable 导出到excel
- 彻底解决C#实现DataTable导出EXCEL表格
- Go 在linux下的安装
- 计算贷款 使用符号常量
- 实用正则表达式匹配和替换
- 3_shuangjingdu.cpp
- UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-4: ordinal not in range(128)
- C# DataTable导出EXCEL后身份证等信息显示乱码解决
- 我爱你,没有什么目的:情感日志
- 4_This is a C++ program.cpp
- 一个指向栈的指针错误,,防不胜防
- Win8 下安装.net framework 3.5
- 采用firebug调试javascript(一)
- 技术项目 - 负载均衡(HAProxy vs Nginx)
- 逝去的流年,渐行渐远,慢慢成为眼角的回忆
- 如何应用autosizing属性使iOS应用程序界面适配iPhone5