在FileSystemWatcher检测到更改后读取文本文件的最后更改

时间:2013-06-13 17:06:19

标签: c# logging io monitoring filesystemwatcher

与我之前的帖子有关:Smartest way to monitor log-files in realtime?
我想要一个FileSystemWatcher来检测文本文件(日志文件)的变化,之后我想让它向我展示最新的变化!

它们是大文件> 50bm,几乎每秒一次全扫描非常耗时 我虽然.last()可以提供帮助,但此代码仅返回最后一行:

 File.ReadText(@"C:\Filename.txt").Last();

我需要一些代码可以继续从最后一个位置读取,然后确定并返回更改。

2 个答案:

答案 0 :(得分:1)

如果您只在文件末尾附加数据,则可以在内存中保存最后读取字节的位置,并且每次从此位置读取到文件末尾您收到通知,该文件已更新。

答案 1 :(得分:1)

FileSystemWatcher不会完全按照您的意愿行事。它会在目录级别看到更改。文件更改后,它没有以前内容的历史记录。在Last()上调用File.ReadText()也没有文件先前状态的概念,这就是为什么它只返回最后一行。

我认为最好的方法是保存EOF的位置,然后每次FSW将你从前一个EOF位置读取的文件更改事件提升到新的EOF,然后更新存储EOF位置的变量。