在项目中需要用FileSystemWatcher对单个文件内容进行监视,文件中每添加一行则需要Fire相应的事件,代码如下
 public class CommandWatcher
   public class CommandWatcher {
    {

 public event EventHandler<CommandEventArgs> CommandHandler;
        public event EventHandler<CommandEventArgs> CommandHandler; 
      
 Fields Fields
        Fields Fields

 public CommandWatcher(string cmdfile)
        public CommandWatcher(string cmdfile) {
        { this.fileName = cmdfile;
            this.fileName = cmdfile; isChangeImmediate = true;
            isChangeImmediate = true;
 
          }
        }


 
         //
        // // Summary:
        // Summary: //     Raises the System.IO.FileSystemWatcher.Changed event.
        //     Raises the System.IO.FileSystemWatcher.Changed event. //
        // // Parameters:
        // Parameters: //   e:
        //   e: //     A System.IO.FileSystemEventArgs that contains the event data.
        //     A System.IO.FileSystemEventArgs that contains the event data. protected void OnChanged(object sender, FileSystemEventArgs e)
        protected void OnChanged(object sender, FileSystemEventArgs e)    {
        { ReloadFile();
            ReloadFile(); }
        }

 
     //
        // // Summary:
        // Summary: //     Raises the System.IO.FileSystemWatcher.Error event.
        //     Raises the System.IO.FileSystemWatcher.Error event. //
        // // Parameters:
        // Parameters: //   e:
        //   e: //     An System.IO.ErrorEventArgs that contains the event data.
        //     An System.IO.ErrorEventArgs that contains the event data. protected void OnError(object sender, ErrorEventArgs e)
        protected void OnError(object sender, ErrorEventArgs e) {
        {
 }
        }
 //
        // // Summary:
        // Summary: //     Raises the System.IO.FileSystemWatcher.Renamed event.
        //     Raises the System.IO.FileSystemWatcher.Renamed event. //
        // // Parameters:
        // Parameters: //   e:
        //   e: //     A System.IO.RenamedEventArgs that contains the event data.
        //     A System.IO.RenamedEventArgs that contains the event data. protected void OnRenamed(object sender, RenamedEventArgs e)
        protected void OnRenamed(object sender, RenamedEventArgs e) {
        {
 }
        }


 /// <summary>
        /// <summary> /// Hook up for the currently selected monitoring method.
        /// Hook up for the currently selected monitoring method. /// </summary>
        /// </summary> public void Start()
        public void Start() {
        { if (isChangeImmediate)
            if (isChangeImmediate) {
            { // stop timer if running
                // stop timer if running ClearTimer();
                ClearTimer(); // If a file is set and the watcher has not been set up yet then create it
                // If a file is set and the watcher has not been set up yet then create it if (null != fileName && null == watcher)
                if (null != fileName && null == watcher) {
                { string path = Path.GetDirectoryName(fileName);
                    string path = Path.GetDirectoryName(fileName); string baseName = Path.GetFileName(fileName);
                    string baseName = Path.GetFileName(fileName); // Use the FileSystemWatcher class to detect changes to the log file immediately
                    // Use the FileSystemWatcher class to detect changes to the log file immediately // We must watch for Changed, Created, Deleted, and Renamed events to cover all cases
                    // We must watch for Changed, Created, Deleted, and Renamed events to cover all cases watcher = new System.IO.FileSystemWatcher(path, baseName);
                    watcher = new System.IO.FileSystemWatcher(path, baseName); FileSystemEventHandler handler = new FileSystemEventHandler(OnChanged);
                    FileSystemEventHandler handler = new FileSystemEventHandler(OnChanged); watcher.Changed += handler;
                    watcher.Changed += handler; watcher.Created += handler;
                    watcher.Created += handler; watcher.Deleted += handler;
                    watcher.Deleted += handler; watcher.Renamed += OnRenamed;
                    watcher.Renamed += OnRenamed; // Without setting EnableRaisingEvents nothing happens
                    // Without setting EnableRaisingEvents nothing happens watcher.EnableRaisingEvents = true;
                    watcher.EnableRaisingEvents = true; }
                } }
            } else
            else {
            { // On a timer so clear the watcher if previously set up
                // On a timer so clear the watcher if previously set up ClearWatcher();
                ClearWatcher(); int numSeconds = 5;
                int numSeconds = 5; 
                if (null != timer)
                if (null != timer) {
                { // Timer is already running so just make sure the interval is correct
                    // Timer is already running so just make sure the interval is correct if (timer.Interval != 1000 * numSeconds)
                    if (timer.Interval != 1000 * numSeconds) {
                    { timer.Interval = 1000 * numSeconds;
                        timer.Interval = 1000 * numSeconds; }
                    } }
                } else
                else {
                { // Fire up a timer if the user entered a valid time interval
                    // Fire up a timer if the user entered a valid time interval if (0 != numSeconds)
                    if (0 != numSeconds) {
                    { timer = new System.Windows.Forms.Timer();
                        timer = new System.Windows.Forms.Timer(); timer.Interval = 1000 * numSeconds;
                        timer.Interval = 1000 * numSeconds; timer.Tick += timerTick;
                        timer.Tick += timerTick; timer.Start();
                        timer.Start(); }
                    } }
                } }
            } this.ReloadFile();
            this.ReloadFile(); }
        }
 void timerTick(object sender, EventArgs e)
        void timerTick(object sender, EventArgs e) {
        { UpdateBasedOnFileTime();
            UpdateBasedOnFileTime(); }
        }

 /// <summary>
        /// <summary> /// Update the log file if the modified timestamp has changed since the last time the file was read.
        /// Update the log file if the modified timestamp has changed since the last time the file was read. /// </summary>
        /// </summary> private void UpdateBasedOnFileTime()
        private void UpdateBasedOnFileTime() {
        { if (null != fileName)
            if (null != fileName) {
            { // This returns "12:00 midnight, January 1, 1601 A.D." if the file does not exist
                // This returns "12:00 midnight, January 1, 1601 A.D." if the file does not exist DateTime newLastModifiedTime = File.GetLastWriteTime(fileName);
                DateTime newLastModifiedTime = File.GetLastWriteTime(fileName); if ((newLastModifiedTime.Year < 1620 && newLastModifiedTime != lastModifiedTime)
                if ((newLastModifiedTime.Year < 1620 && newLastModifiedTime != lastModifiedTime) || newLastModifiedTime > lastModifiedTime)
                    || newLastModifiedTime > lastModifiedTime) {
                { //OnLogFileChanged();
                    //OnLogFileChanged(); ReloadFile();
                    ReloadFile(); }
                } }
            } }
        } /// <summary>
        /// <summary> /// Read the log file.
        /// Read the log file. /// </summary>
        /// </summary> /// <remarks>If the user has some text selected then keep that text selected.</remarks>
        /// <remarks>If the user has some text selected then keep that text selected.</remarks> private void ReloadFile()
        private void ReloadFile() {
        { if (reloadingFile) return; // already busy doing this
            if (reloadingFile) return; // already busy doing this reloadingFile = true;
            reloadingFile = true; try
            try {
            { if (null == fileName)
                if (null == fileName) {
                { // textBoxContents.Text = "";
                   // textBoxContents.Text = ""; }
                } else
                else {
                { string newFileLines = "";
                    string newFileLines = ""; lastModifiedTime = File.GetLastWriteTime(fileName); // Remember when we last read in this file
                    lastModifiedTime = File.GetLastWriteTime(fileName); // Remember when we last read in this file long newLength = 0;  // will be set properly later if all is well
                    long newLength = 0;  // will be set properly later if all is well bool fileExists = File.Exists(fileName);
                    bool fileExists = File.Exists(fileName); bool needToClear = !fileExists;
                    bool needToClear = !fileExists; if (fileExists)
                    if (fileExists) {
                    { // It is possible the file will be in use when we read it (especially if using Immediate mode)
                        // It is possible the file will be in use when we read it (especially if using Immediate mode) // So, we will try up to 5 times to access the file
                        // So, we will try up to 5 times to access the file int count = 0;
                        int count = 0; bool success = false;
                        bool success = false; while (count < 5 && !success)
                        while (count < 5 && !success) {
                        { try
                            try {
                            { // Open with the least amount of locking possible
                                // Open with the least amount of locking possible using (FileStream stream = File.Open(fileName, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite))
                                using (FileStream stream = File.Open(fileName, FileMode.Open, FileAccess.ReadWrite, FileShare.ReadWrite)) {
                                { newLength = stream.Length;
                                    newLength = stream.Length; if (newLength >= lastFileSize)
                                    if (newLength >= lastFileSize) {
                                    { stream.Position = lastFileSize;  // Only read in new lines added
                                        stream.Position = lastFileSize;  // Only read in new lines added }
                                    } else
                                    else {
                                    { needToClear = true;
                                        needToClear = true; }
                                    } using (StreamReader reader = new StreamReader(stream))
                                    using (StreamReader reader = new StreamReader(stream)) {
                                    { newFileLines = reader.ReadToEnd();
                                        newFileLines = reader.ReadToEnd();
 if (newFileLines != string.Empty)
                                        if (newFileLines != string.Empty) {
                                        { if (this.CommandHandler != null)
                                            if (this.CommandHandler != null) this.CommandHandler(this, new CommandEventArgs(newFileLines));
                                                this.CommandHandler(this, new CommandEventArgs(newFileLines)); }
                                        } 
                                       //string []tmp = newFileLines.Split(seprater, StringSplitOptions.RemoveEmptyEntries);
                                        //string []tmp = newFileLines.Split(seprater, StringSplitOptions.RemoveEmptyEntries);
 }
                                    } }
                                } success = true;
                                success = true; }
                            } catch (IOException)
                            catch (IOException) {
                            { System.Threading.Thread.Sleep(50); // Give a little while to free up file
                                System.Threading.Thread.Sleep(50); // Give a little while to free up file }
                            } ++count;
                            ++count; }
                        } }
                    } // Remember the current file length so we can read only newly added log lines the next time the log file is read
                    // Remember the current file length so we can read only newly added log lines the next time the log file is read lastFileSize = newLength;
                    lastFileSize = newLength; if(lastFileSize > 1024 * 1024 * 2)
                    if(lastFileSize > 1024 * 1024 * 2) {
                    { File.Delete(fileName);
                        File.Delete(fileName); File.Create(fileName);
                        File.Create(fileName); }
                    }                    
                if (0 != newFileLines.Length)
                    if (0 != newFileLines.Length) {
                    { // See if this log file has proper cr/lf and if not convert
                        // See if this log file has proper cr/lf and if not convert int lastCr = newFileLines.LastIndexOf('\n');
                        int lastCr = newFileLines.LastIndexOf('\n'); if (-1 != lastCr && 0 < lastCr)
                        if (-1 != lastCr && 0 < lastCr) {
                        { if (newFileLines[lastCr - 1] != '\r')
                            if (newFileLines[lastCr - 1] != '\r') {
                            { // OK, this file only has Cr and we need to convert to CrLf
                                // OK, this file only has Cr and we need to convert to CrLf newFileLines = newFileLines.Replace("\n", "\r\n");
                                newFileLines = newFileLines.Replace("\n", "\r\n"); }
                            } }
                        } }
                    } 
                     
                    }
                } }
            } finally
            finally {
            { // Put clearing this flag in a finally so we know it will be cleared
                // Put clearing this flag in a finally so we know it will be cleared reloadingFile = false;
                reloadingFile = false; }
            } }
        }

 /// <summary>
        /// <summary> /// Cleanup the <see cref="Timer"/>
        /// Cleanup the <see cref="Timer"/> /// </summary>
        /// </summary> private void ClearTimer()
        private void ClearTimer() {
        { if (null != timer)
            if (null != timer) {
            { timer.Tick -= timerTick;
                timer.Tick -= timerTick; timer.Dispose();
                timer.Dispose(); timer = null;
                timer = null; }
            } }
        }
 /// <summary>
        /// <summary> /// Cleanup the <see cref="FileSystemWatcher"/>
        /// Cleanup the <see cref="FileSystemWatcher"/> /// </summary>
        /// </summary> private void ClearWatcher()
        private void ClearWatcher() {
        { if (null != watcher)
            if (null != watcher) {
            { FileSystemEventHandler handler = new FileSystemEventHandler(OnChanged);
                FileSystemEventHandler handler = new FileSystemEventHandler(OnChanged); watcher.Changed -= handler;
                watcher.Changed -= handler; watcher.Created -= handler;
                watcher.Created -= handler; watcher.Deleted -= handler;
                watcher.Deleted -= handler; watcher.Renamed -= OnRenamed;
                watcher.Renamed -= OnRenamed; watcher.Dispose();
                watcher.Dispose(); watcher = null;
                watcher = null; }
            } }
        }


 }
    } 
                    
                     
                    
                 
                    
                 
 
    
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号