PHP生成Excel, 控制Excel单元格中的换行符

巴扎黑
发布: 2016-11-30 11:49:03
原创
2565人浏览过

公司使用mantis管理bug, mantis有一个功能, 将bug导出为excel,

但是目前的这个mantis版本, 在导出excel的时候, "摘要,说明,问题重现步骤说明,附加信息,评论"等等这些信息中,

提交bug时候的回车换行符都不见了, 因为没有了格式, 在excel中读起来很不方便,

这回想改善的便是这个问题,

在使用php做成excel的时候, 如何在一个excel cell内写入换行符, 控制该单元格的格式.

立即学习PHP免费学习笔记(深入)”;

我试验了一下, \r\n在生成excel的时候, 是无效的, 会被过滤调.

但是要是写入<br>, 起到的效果不是单元格内换行, 而是换了一个新的单元格.

google了下, 要想达到单元格内换行的目的, 需要插入下面这个字符串  

吉卜力风格图片在线生成
吉卜力风格图片在线生成

将图片转换为吉卜力艺术风格的作品

吉卜力风格图片在线生成 121
查看详情 吉卜力风格图片在线生成
'<br style="mso-data-placement:same-cell;" />'
登录后复制

另外我调查的过程中, 来发现了另外一个有趣的问题.

前面已经提到, 在用php生成excel的时候, \r\n是不起任何换行作用的, 要想控制换行, 需要借助html标记.

但是, 如果把\r\n夹杂在<pre> </pre>中间,

形如下面这样, 那么, 这时候的\r\n相当于一个<br>, 会在做成的excel中, 新起一个单元格.

写道<pre>
..........\r\n
..........\r\n
..........\r\n
</pre> 

这种行为显然也不是我们想要的,

所以还是像下面这样, 把他们统统替换掉吧.  

$p_new_lines   = array("\r\n", "\n", "\r","\r\n", "<pre>","</pre>","<br>","</br>","<br/>");  
$p_change_line_in_excel_cell = '<br style="mso-data-placement:same-cell;" />';  
$p_result = str_replace( $p_new_lines,$p_change_line_in_excel_cell,$p_input);
登录后复制
相关标签:
WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号