[C#] FileSystemWatcherの設定方法と活用法
FileSystemWatcherは、C#でファイルシステムの変更を監視するためのクラスです。
設定方法は、まずインスタンスを作成し、Path
プロパティで監視するディレクトリを指定します。
次に、Filter
プロパティで監視するファイルの種類を設定します。
NotifyFilter
プロパティで監視する変更の種類(例:ファイル名、サイズ、属性の変更など)を指定し、EnableRaisingEvents
をtrue
に設定して監視を開始します。
イベントハンドラを追加して、Changed
、Created
、Deleted
、Renamed
などのイベントを処理します。
活用法としては、ログファイルの更新監視や、特定ディレクトリへのファイル追加をトリガーにした処理の自動化などがあります。
FileSystemWatcherの設定方法
インスタンスの作成
FileSystemWatcher
を使用するには、まずインスタンスを作成します。
以下のコードは、FileSystemWatcher
のインスタンスを作成する方法を示しています。
partial class MyForm : Form
{
private FileSystemWatcher fileSystemWatcher;
public MyForm()
{
InitializeComponent(); // フォームの初期化
fileSystemWatcher = new FileSystemWatcher(); // インスタンスの作成
}
}
監視するディレクトリの指定
次に、監視したいディレクトリを指定します。
Path
プロパティを使用して、監視対象のパスを設定します。
fileSystemWatcher.Path = @"C:\監視するディレクトリ"; // 監視するディレクトリの指定
監視するファイルの種類の設定
監視するファイルの種類を指定するには、Filter
プロパティを使用します。
特定の拡張子のファイルのみを監視することができます。
fileSystemWatcher.Filter = "*.txt"; // 監視するファイルの種類の設定(例:テキストファイル)
変更の種類の指定
FileSystemWatcher
では、どのような変更を監視するかを指定することができます。
NotifyFilter
プロパティを使用して、監視する変更の種類を設定します。
fileSystemWatcher.NotifyFilter = NotifyFilters.FileName | NotifyFilters.LastWrite; // 変更の種類の指定
イベントハンドラの追加
ファイルやディレクトリに変更があった際に実行されるイベントハンドラを追加します。
以下のコードでは、ファイルが変更されたときの処理を定義しています。
fileSystemWatcher.Changed += new FileSystemEventHandler(OnChanged); // イベントハンドラの追加
private void OnChanged(object sender, FileSystemEventArgs e)
{
// 変更があったファイルの情報を表示
MessageBox.Show($"ファイルが変更されました: {e.FullPath}");
}
監視の開始と停止
最後に、監視を開始するにはEnableRaisingEvents
プロパティをtrue
に設定します。
監視を停止する場合は、false
に設定します。
fileSystemWatcher.EnableRaisingEvents = true; // 監視の開始
// fileSystemWatcher.EnableRaisingEvents = false; // 監視の停止(必要に応じて)
これで、FileSystemWatcher
の基本的な設定が完了しました。
ファイルやディレクトリの変更をリアルタイムで監視することができます。
FileSystemWatcherの活用法
ログファイルの更新監視
FileSystemWatcher
を使用して、特定のログファイルの更新を監視することができます。
ログファイルが更新されるたびに、変更内容を取得して処理を行うことが可能です。
以下のコードは、ログファイルの更新を監視する例です。
fileSystemWatcher.Path = @"C:\ログファイルのディレクトリ"; // 監視するディレクトリの指定
fileSystemWatcher.Filter = "log.txt"; // 監視するファイルの種類の設定
fileSystemWatcher.Changed += new FileSystemEventHandler(OnLogFileChanged); // イベントハンドラの追加
private void OnLogFileChanged(object sender, FileSystemEventArgs e)
{
// ログファイルの内容を読み込む処理
string logContent = File.ReadAllText(e.FullPath); // 更新されたログファイルの内容を取得
MessageBox.Show($"ログファイルが更新されました:\n{logContent}"); // 更新内容を表示
}
ファイル追加をトリガーにした処理の自動化
新しいファイルが指定したディレクトリに追加されたときに、自動的に処理を実行することができます。
以下のコードは、ファイル追加をトリガーにした処理の例です。
fileSystemWatcher.Created += new FileSystemEventHandler(OnFileCreated); // ファイル追加のイベントハンドラの追加
private void OnFileCreated(object sender, FileSystemEventArgs e)
{
// 新しく追加されたファイルに対する処理
MessageBox.Show($"新しいファイルが追加されました: {e.FullPath}"); // 追加されたファイルのパスを表示
}
ディレクトリのバックアップ
FileSystemWatcher
を利用して、特定のディレクトリのバックアップを自動化することができます。
ファイルが変更された際に、バックアップを作成する処理を実行します。
以下のコードは、バックアップ処理の例です。
fileSystemWatcher.Changed += new FileSystemEventHandler(OnFileChangedForBackup); // 変更イベントのハンドラの追加
private void OnFileChangedForBackup(object sender, FileSystemEventArgs e)
{
string backupPath = @"C:\バックアップディレクトリ\" + Path.GetFileName(e.FullPath); // バックアップ先のパス
File.Copy(e.FullPath, backupPath, true); // ファイルをバックアップ
MessageBox.Show($"バックアップが作成されました: {backupPath}"); // バックアップ完了のメッセージ
}
ファイルの変更履歴の記録
ファイルの変更履歴を記録するために、FileSystemWatcher
を使用することができます。
変更があったファイルの情報をログファイルに記録する例を以下に示します。
fileSystemWatcher.Changed += new FileSystemEventHandler(OnFileChangedForHistory); // 変更イベントのハンドラの追加
private void OnFileChangedForHistory(object sender, FileSystemEventArgs e)
{
string logEntry = $"{DateTime.Now}: {e.FullPath} が変更されました。\n"; // 変更履歴のエントリ
File.AppendAllText(@"C:\変更履歴.txt", logEntry); // 変更履歴をファイルに追加
}
これらの活用法を通じて、FileSystemWatcher
を使ったさまざまな自動化処理を実現することができます。
FileSystemWatcherの応用例
複数ディレクトリの同時監視
FileSystemWatcher
を複数インスタンス作成することで、異なるディレクトリを同時に監視することができます。
以下のコードは、2つの異なるディレクトリを監視する例です。
private FileSystemWatcher watcher1;
private FileSystemWatcher watcher2;
public MyForm()
{
InitializeComponent(); // フォームの初期化
watcher1 = new FileSystemWatcher(@"C:\ディレクトリ1"); // 1つ目のディレクトリの監視
watcher2 = new FileSystemWatcher(@"C:\ディレクトリ2"); // 2つ目のディレクトリの監視
watcher1.Changed += new FileSystemEventHandler(OnChanged1); // 1つ目の監視イベント
watcher2.Changed += new FileSystemEventHandler(OnChanged2); // 2つ目の監視イベント
watcher1.EnableRaisingEvents = true; // 1つ目の監視開始
watcher2.EnableRaisingEvents = true; // 2つ目の監視開始
}
private void OnChanged1(object sender, FileSystemEventArgs e)
{
MessageBox.Show($"ディレクトリ1で変更がありました: {e.FullPath}");
}
private void OnChanged2(object sender, FileSystemEventArgs e)
{
MessageBox.Show($"ディレクトリ2で変更がありました: {e.FullPath}");
}
ネットワークドライブの監視
FileSystemWatcher
は、ローカルディレクトリだけでなく、ネットワークドライブの監視にも使用できます。
以下のコードは、ネットワークドライブを監視する例です。
fileSystemWatcher.Path = @"\\ネットワークドライブ\共有フォルダ"; // ネットワークドライブの指定
fileSystemWatcher.EnableRaisingEvents = true; // 監視の開始
fileSystemWatcher.Changed += new FileSystemEventHandler(OnNetworkDriveChanged); // 変更イベントのハンドラの追加
private void OnNetworkDriveChanged(object sender, FileSystemEventArgs e)
{
MessageBox.Show($"ネットワークドライブで変更がありました: {e.FullPath}"); // 変更内容を表示
}
大量のファイル変更への対応
大量のファイルが一度に変更される場合、FileSystemWatcher
は複数のイベントを発生させることがあります。
この場合、イベントの重複を避けるために、適切な処理を行う必要があります。
以下のコードは、変更イベントをまとめて処理する例です。
private bool isProcessing = false; // 処理中フラグ
private void OnChanged(object sender, FileSystemEventArgs e)
{
if (isProcessing) return; // すでに処理中の場合は無視
isProcessing = true; // 処理中フラグを立てる
// 変更処理を実行
MessageBox.Show($"ファイルが変更されました: {e.FullPath}");
isProcessing = false; // 処理完了
}
パフォーマンスの最適化
FileSystemWatcher
を使用する際は、パフォーマンスを最適化するために、必要なプロパティのみを設定し、イベントハンドラ内での処理を軽量に保つことが重要です。
以下のポイントに注意して最適化を行います。
- NotifyFilterの設定: 監視する変更の種類を必要最低限に設定する。
- フィルタリング:
Filter
プロパティを使用して、特定のファイルタイプのみを監視する。 - 非同期処理: イベントハンドラ内での重い処理は、別スレッドで実行することを検討する。
private void OnChanged(object sender, FileSystemEventArgs e)
{
Task.Run(() =>
{
// 重い処理を非同期で実行
ProcessFileChange(e.FullPath);
});
}
private void ProcessFileChange(string filePath)
{
// ファイル変更に対する処理
// ここに重い処理を記述
}
これらの応用例を通じて、FileSystemWatcher
をより効果的に活用し、さまざまなシナリオに対応することができます。
まとめ
この記事では、C#のFileSystemWatcher
を使用したファイルやディレクトリの監視方法について詳しく解説しました。
具体的には、インスタンスの作成から監視の開始、さらには実際の活用法や応用例に至るまで、幅広く取り上げました。
これを機に、FileSystemWatcher
を活用して、ファイルシステムの変更をリアルタイムで監視し、さまざまな自動化処理を実現してみてください。