表題の通りです.
例えばブラウザからZipファイルをダウンロードした時, ダウンロードフォルダを監視してフォルダに入ってきたzipファイルを自動で解凍する, みたいなことがしたいです.
Python
1from watchdog.events import FileSystemEventHandler 2from watchdog.observers import Observer 3 4import os 5import time 6import zipfile 7 8target_dir = r"C:/Users/teratail/Downloads" 9os.chdir(target_dir) 10 11class ChangeHandler(FileSystemEventHandler): 12 def on_created(self, event): 13 filepath = event.src_path 14 filename = os.path.basename(filepath) 15 print(filepath) 16 if zipfile.is_zipfile(filepath): 17 with zipfile.ZipFile(filename,'r') as zf: 18 zf.extractall(target_dir) 19 print('Zipファイルを解凍しました') 20 else: 21 print('%sができました' % filename) 22 23 def on_deleted(self, event): 24 filepath = event.src_path 25 filename = os.path.basename(filepath) 26 print('%sを削除しました' % filename) 27 28if __name__ in '__main__': 29 while 1: 30 event_handler = ChangeHandler() 31 observer = Observer() 32 observer.schedule(event_handler, target_dir, recursive=True) 33 observer.start() 34 try: 35 while True: 36 time.sleep(0.1) 37 except KeyboardInterrupt: 38 observer.stop() 39 observer.join()
しかし実際に実行して,zipファイルをフォルダに入れても if zipfile.is_zipfile(filepath): がFalseになります. この場合だとfilepathがおかしいのかなと一応printで確認すると
C:/Users/Teratail/Downloads\sample.zip
で,問題はなさそうです/
(一応\sample.zipがいけないのか?と思い\や/に全部統一などもしましたが結果は変わらず)
ご意見,回答をお待ちしています.
「print('%sができました' % filename)」の方が出力されているということですか?
そうなります. 現状はwatchdogのフォルダ監視が問題(フォルダに入った瞬間,データがコピーされきってないのに処理をしてしまって不具合が出ている)だと気付いて, フォルダを確認した後3~5秒待ってから処理をするようにしたら上手くいくようにはなりました.
が,その後展開したフォルダーについてPermissionError: [Errno 13]が出るようになりました...;;
こちらの質問が既に解決済であれば「自己解決で解決済」にして、新たにPermissonエラーについての質問をされた方が良いです。その方が詳しい方から回答が付くでしょう。
回答1件
あなたの回答
tips
プレビュー