从前,用asp.net core写了一个给客户发交易明细的应用,每天发一次,因为是csv格式,当时用的是StringBuilder来一行一行组装数据,组装完后,EMali或SFTP给客户。
后来,为节省服务器资源,需要把服务从windows server迁移到Linux上,经过反复测试,都没有发现Bug,就上线了。结果悲剧发生了,用户说我们传的csv格式与以前不一样,我们打开怎么看都是对的,后来,在“心(ri)细(ben)”的同事提示下,我们用sakura文本编辑器打开查看,果不其然,每个换行都不一样,原来在windows下是“\r\n”,在Linux上是“\n”,为什么呢?看代码吧。
WriteLine("---------StringBuilder---------");var contentBuilder = new StringBuilder();contentBuilder.AppendLine("line00001");contentBuilder.AppendLine("line00002");contentBuilder.AppendLine("line00003");var content = contentBuilder.ToString();Console.WriteLine(content);//为了显示出\r\n进行一个替换Console.WriteLine(content.Replace("\r", "\\r").Replace("\n", "\\n"));Console.WriteLine();Console.WriteLine();//Environment.NewLin也同样是这个坑Console.WriteLine("---------Environment.NewLine-------- ");content = "line0000A" + Environment.NewLine + "line0000B";Console.WriteLine(content);Console.WriteLine();Console.WriteLine(content.Replace("\r", "\\r").Replace("\n", "\\n"));ReadLine();
这是windows下的输出
这是mac下的输出
这是ubuntu下的输出
这是docker(windows下的WSL)下的输出