var fs = new FileStream(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite);
using(var writer = new StreamWriter(fs))
writer.Write(....);如果文件以前包含的文本和新编写的文本比文件中已有的文本短,如何确保文件中过时的尾随内容被截断?
请注意,在这种情况下,以截断模式打开文件不是一个选项。当我收到FileStream对象时,该文件已经打开。上面的代码只是为了说明流的属性。
编辑
根据下面的答案展开,解决方案是:
var fs = new FileStream(filePath, FileMode.OpenOrCreate, FileAccess.ReadWrite);
using(var writer = new StreamWriter(fs))
{
writer.Write(....);
writer.Flush();
fs.SetLength(fs.Position);
}发布于 2011-12-11 21:29:45
使用SetLength设置文件的新长度-文件应被截断。
请参阅相关问题的this answer。
发布于 2011-12-11 21:29:07
你可以试试writer.BaseStream.SetLength(writer.BaseStream.Position),尽管我不确定它会有多好。
对于FileStream,我认为这应该将文件截断到当前位置。
发布于 2017-03-16 23:48:46
如果日志文件的大小超过1 MB,此代码将截断该文件的一部分。
using (FileStream fs = File.Open("C:\\LogFile.txt", FileMode.OpenOrCreate))
{
int OneMB = 1000000;
fs.Seek(0, SeekOrigin.Begin);
if (fs.Length > OneMB)
{
int fileByte = 1;
fs.Position = fs.Seek(fs.Length / 2, SeekOrigin.Begin);
List<byte> bytes = new List<byte>();
while (fileByte > 0)
{
fileByte = fs.ReadByte();
bytes.Add((byte)fileByte);
}
fs.SetLength(0);
fs.Position = 0;
fs.Write(bytes.ToArray(), 0, bytes.Count());
fs.Seek(0, SeekOrigin.End);
var stringBytes = UTF8Encoding.ASCII.GetBytes($"Test1" + Environment.NewLine);
fs.Write(stringBytes, 0, stringBytes.Length);
}
else
{
fs.Seek(0, SeekOrigin.End);
var stringBytes = UTF8Encoding.ASCII.GetBytes($"Test2" + Environment.NewLine);
fs.Write(stringBytes, 0, stringBytes.Length);
}
fs.Flush();
}
}https://stackoverflow.com/questions/8464261
复制相似问题