今天在工作相关中,利用poi将excel单元格中的换行去除,转化为txt文档,使用正则表达式.replaceAll("[ \n]+"," ")进行替换,发现毫无作用
但是正则表达式界面显示是正确的
然后发现可能是上传的服务器使用windows系统,即系统区分换行符的差别,将总结如下(参考博客\r,\n,\r\n的区别 - 小 天 - 博客园 (cnblogs.com))
在Windows中:
'\r' 回车,回到当前行的行首,而不会换到下一行,如果接着输出的话,本行以前的内容会被逐一覆盖;
'\n' 换行,换到当前位置的下一行,而不会回到行首;
Unix系统里,每行结尾只有“<换行>”,即"\n";Windows系统里面,每行结尾是“<回车><换行>”,即“\r\n”;Mac系统里,每行结尾是“<回车>”,即"\r";。一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;而Windows里的文件在Unix/Mac下打开