質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1070閲覧

watchdogモジュールを使ってファイル更新を監視したいが、1度の更新で複数回監視してしまう。

taka3391

総合スコア5

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2023/03/13 21:54

編集2023/03/14 09:15

実現したいこと

watchdogモジュールを使って、ファイルが更新されたときに、処理を走らせたい

発生している問題・エラーメッセージ

ファイルが更新されたときに、処理を走らせたいのですが、1度の更新で複数回処理がよばれてしまっています。
ファイルは約10秒に一度、更新されます。

該当のソースコード

Python

1from time import sleep 2import os 3import shutil 4import datetime 5import soundfile as sf 6import numpy as np 7from multiprocessing import shared_memory 8from settings import * 9from analyze_recog_result import AnalyzeRecogResult 10from watchdog.observers import Observer 11from watchdog.events import PatternMatchingEventHandler 12 13rec_shm = shared_memory.SharedMemory(name=share_mem_name) 14rec_arr = np.ndarray(shape=(rec_sample_num), dtype=float, buffer=rec_shm.buf) 15 16class WatchdogHandler(PatternMatchingEventHandler): 17 def __init__(self, patterns): 18 super(WatchdogHandler, self).__init__(patterns=patterns) 19 self.start_sample = 0 20 21 def on_modified(self, event): 22 shutil.copyfile('temp/temp_rec_data_16k.wav', 'temp/copied_file.wav') 23 data, samplerate = sf.read(tmp_wav_path_copy) 24 rec_arr[self.start_sample:self.start_sample + len(data)] = data 25 self.start_sample = self.start_sample + len(data) 26 print(str(datetime.datetime.now().time())) 27 28 29 30if __name__ == "__main__": 31 event_handler = WatchdogHandler(['temp_rec_data_16k.wav']) 32 33 observer = Observer() 34 observer.schedule(event_handler, 'temp/', recursive=True) 35 observer.start() 36 37 try: 38 while True: 39 sleep(1) 40 finally: 41 observer.stop() 42 observer.join()

on_modified関数のprint文が以下のように表示されており、複数回呼ばれているようです。

06:40:32.536681
06:40:32.553222
06:40:32.572928
06:40:32.587926

処理を1度だけ走らせるには、どうしたらよいでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

自己解決しました。
PollingObserverを使うことで解決しました。
pythonでwatchdogのイベントが二回発火してる原因が分からない

投稿2023/03/14 00:15

taka3391

総合スコア5

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問