使用看门狗,我希望它在某个目录中查找更新的文件,如果更新的文件,它会获取文件名并运行带有文件名的特定脚本,并将输出作为txt文件发送到另一个目录。当文本文件出现在新目录中时,以某种方式获取该文件的名称并将其设置为用于分析的变量。
例:
第一个目录/path/to/ First /dir/2017/04/27/nfcapd.20170427 <- New File (注意,不是txt文件)
脚本通过使用上面的文件名在下面的文件中获取数据。
nfdump -r nfcapd.20170427 >home/user/rmaestas/nfcapd.20170427.txt
文件名存储在一个变量中,以便与代码一起使用。
updated = 'nfcapd.21070427.txt’
filename = ('home/users/rmaestas/') #<-- insert 'updated in directory'
with open(filename, 'r') as infile:
next(infile) #Skips the first row, first row is not data.
for line in infile:#read every line
if "Summary:" in line:#End of the data, last4 lines are a summary which won't be needed.
break
print(line.split()[4].rsplit(':', 1)[0])
#more code... 发布于 2017-06-19 05:24:37
您需要做的是创建一个继承文件处理程序之一的类,并覆盖在更新文件时将调用的on_modified方法,如下所示
class CustomFileEventHandler(FileSystemHandler):
def on_modified(self, event):
file_name = event.src_path #get's the path of the modified file
with open(file_name, "r") as infile, open("path/to/file.txt", "w") as result:
#call your function which should return a string
result.write(function output) #instead of print没有必要追加“home/user/rmaestas”,因为.src_path会为您提供文件的完整路径。
然后,使用重写的FileSystemHandler,您需要设置观察者,它将实际执行与看门狗文档中给出的示例类似的监视
event_handler = CustomFileEventHandler()
observer = Observer()
observer.schedule(event_handler, "path/to/dir", recursive=False)
observer.start()
try:
while True:
time.sleep(1)
except KeyboardInterrupt:
observer.stop()
observer.join()https://stackoverflow.com/questions/43671762
复制相似问题