您的位置:首页 > 编程语言 > ASP

ASP.NET GridView导出Excel 打印预览换行显示不全

2014-02-07 12:05 591 查看
最近发现一个问题,我的一篇博客(Asp.net中把DataTable或DataGrid导出为Excel)中提到的导出Excel的方法,导出的Excel文档,如果单元格的内容比较满(未换行),打印预览的时候,这个单元格会自动换行,而且行高不变,导致显示不全。
有人说这是一种“误差”,是由于Excel的“所见即所得”功能和打印控制程序的不一致造成的。(百度


最懒的办法就是在单元格加一个换行了。但是这个换行也不是这么好加的,试过 <br/> /r/n 等等,都没有用。最后大海捞针捞到一篇文章,才解决了。

解决方案如下:

在需要换行的地方,插入

<br style='mso-data-placement:same-cell;'/>


基于DataTableToExcel的示例:

DataTable.Rows[0]["商品名称"] += "<br/>";  //注意<br/>中的尖括号会被转义


gvExport.RenderControl(htmlWriter);
curContext.Response.Clear();
//换行转换
curContext.Response.Write("<meta http-equiv=\"content-type\" content=\"application/ms-excel; charset=gb2312\"/>" + strWriter.ToString().Replace("<br/>", "<br style='mso-data-placement:same-cell;'/>"));
curContext.Response.End();


参考:http://www.jb51.net/article/16837.htm
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: