OS X上Python中的看门狗库没有显示完整的事件路径

2024-04-18 23:34:08 发布

您现在位置:Python中文网/ 问答频道 /正文

我刚开始在Mac上使用Python中的Watchdog library,并正在进行一些基本测试,以确保一切正常。不幸的是,它们不是——我似乎只能获得注册事件的文件所在文件夹的路径,而不是文件本身的路径。在

下面是一个简单的测试程序(根据Watchdog提供的示例稍作修改),在注册事件时打印出事件类型、路径和时间。在

import time
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler
from watchdog.events import FileSystemEventHandler

class TestEventHandler(FileSystemEventHandler):

def on_any_event(self, event):
    print("event noticed: " + event.event_type + 
                 " on file " + event.src_path + " at " + time.asctime())

if __name__ == "__main__":
    event_handler = TestEventHandler()
    observer = Observer()
    observer.schedule(event_handler, path='~/test', recursive=True)
    observer.start()
    try:
        while True:
            time.sleep(1)
    except keyboardInterrupt:
        observer.stop()
    observer.join()

src_path变量应包含发生事件的文件的路径。在

但是,在我的测试中,当我修改一个文件时,src_path只打印包含该文件的文件夹的路径,而不是文件本身的路径。例如,当我修改文件夹europa中的文件moon.txt时,程序将打印以下输出:

^{pr2}$

要获得修改文件的完整路径,我需要做什么更改?在


Tags: 文件pathfromimport路径src文件夹event
2条回答

问题解决了。事实证明,OSX中的FSEvents只返回文件修改事件的目录,让您自己扫描该目录以找出修改了哪个文件。虽然在FSEvents文档中很容易找到,但在Watchdog文档中并没有提到这一点。在

为了获得文件的完整路径,我添加了以下代码片段(inspired by this StackOverflow thread)以在目录中查找最近修改过的文件,以便在任何时候使用event.src_路径返回一个目录。在

if(event.is_directory):
    files_in_dir = [event.src_path+"/"+f for f in os.listdir(event.src_path)]
    mod_file_path = max(files_in_dir, key=os.path.getmtime)

mod_file_path包含修改文件的完整路径。在

感谢ekl提供您的解决方案。我只是偶然发现了同样的问题。但是,我以前使用PatternMatchingEventHandler,它需要对您的解决方案进行一些小的更改:

  • FileSystemEventHandler的子类
  • 创建一个存储模式匹配的属性pattern。这不像最初的PatternMatchingEventHandler那么灵活,但是应该可以满足大多数需求,如果您想扩展它,您无论如何都会得到这个想法。在

以下是您必须放入FileSystemEventHandler子类中的代码:

def __init__(self, pattern='*'):
    super(MidiEventHandler, self).__init__()
    self.pattern = pattern


def on_modified(self, event):
    super(MidiEventHandler, self).on_modified(event)

    if event.is_directory:
        files_in_dir = [event.src_path+"/"+f for f in os.listdir(event.src_path)]
        if len(files_in_dir) > 0:
            modifiedFilename = max(files_in_dir, key=os.path.getmtime)
        else:
            return
    else:
        modifiedFilename = event.src_path

    if fnmatch.fnmatch(os.path.basename(modifiedFilename), self.pattern):
        print "Modified MIDI file: %s" % modifiedFilename

我更改的另一件事是在对文件列表运行max()之前检查目录是否为空。max()不能处理空列表。在

相关问题 更多 >