为什么空白会出现在C#TextWriter文件的末尾?

时间:2019-08-28 10:15:14

标签: c# textwriter

我已经使用TextWriter C#创建了一个文本文件,最终创建时,该文本文件通常在文件末尾具有多行空白。组成文件的任何字符串对象中均不包含空格,我也不知道是什么原因引起的。文件越大,空格越多。

我已经尝试了各种测试,以根据字符串上的内容查看是否出现空格,但是事实并非如此。也就是说,我已经确定了空白开始的行数,并为完全不同的内容更改了字符串,但是空白仍然存在。

//To start:
MemoryStream memoryStream = new MemoryStream();
TextWriter tw = new StreamWriter(memoryStream);

//Loop through records & create a concatenated string object
string strUTL1 = string.Format("{0}{1}{2}{3}{4}{5}{6}{7}", strUTL1_1, strUTL1_2, strUTL1_3, strUTL1_4, strUTL1_5, strUTL1_6, strUTL1_7, strUTL1_8);

//Add the line to the text file
tw.WriteLine(strUTL1);

//Once all rows are added I complete the file
tw.Flush();
tw.Close();


//Then return the file
return File(memoryStream.GetBuffer(), "text/plain", txtFileName);

我不想在完成后操作文件(例如替换空格),因为这可能会导致其他问题。该文件将与第三方交换,并且需要正确格式化。

谢谢您的帮助。

3 个答案:

答案 0 :(得分:3)

the doc for MemoryStream.GetBuffer explains

  

请注意,缓冲区包含分配的字节,这些字节可能未使用。例如,如果将字符串“ test”写入MemoryStream对象,则从GetBuffer返回的缓冲区的长度为256,而不是4,未使用252个字节。要仅获取缓冲区中的数据,请使用ToArray方法。但是,ToArray会在内存中创建数据的副本。

使用.ToArray()(它将分配一个合适大小的新数组),或者您可以使用从.GetBuffer()返回的缓冲区,但是您需要检查.Length才能看到其中有多少个有效字节。

答案 1 :(得分:1)

GetBuffer()返回所有已分配的内存,几乎总是比实际写入的字节更多。

我建议改用Encoding.UTF8.GetBytes(...)

string strUTL1 = string.Format("{0}{1}{2}{3}{4}{5}{6}{7}", strUTL1_1, strUTL1_2, strUTL1_3, strUTL1_4, strUTL1_5, strUTL1_6, strUTL1_7, strUTL1_8);

var bytes = Encoding.UTF8.GetBytes(strUTL1);

return File(bytes, "text/plain", txtFileName);

答案 2 :(得分:0)

使用ToArray()代替GetBuffer(),因为缓冲区大于所需的缓冲区。

通常是这种情况。与缓冲区一起使用的类或函数通常会保留一定大小的内存来保存数据。然后,该函数将返回一个值,即已将多少字节写入缓冲区。然后,您只能使用缓冲区的前 n 个字节。

MSDN的引用:

  

例如,如果将字符串“ test”写入MemoryStream对象,则从GetBuffer()返回的缓冲区的长度为256,而不是4,未使用252个字节。要仅获取缓冲区中的数据,请使用ToArray()方法;但是,ToArray()在内存中创建数据的副本。