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

来源:互联网 发布:在淘宝买东西怎么返利 编辑:程序博客网 时间:2024/06/11 00:09
最近发现一个问题,我的一篇博客(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("&lt;br/&gt;", "<br style='mso-data-placement:same-cell;'/>"));                curContext.Response.End();


参考:http://www.jb51.net/article/16837.htm





0 0
原创粉丝点击