第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

Python - 如何獲取日志附加內(nèi)容

Python - 如何獲取日志附加內(nèi)容

胡子哥哥 2022-06-02 15:13:48
我使用看門(mén)狗來(lái)查看日志的更改,但我無(wú)法從看門(mén)狗 API 參考中獲取附加內(nèi)容。還有其他方法可以實(shí)現(xiàn)這一點(diǎn)嗎?from watchdog.observers import Observerfrom watchdog.events import FileSystemEventHandlerimport timeimport osclass MyHandler(FileSystemEventHandler):    def on_modified(self, event):        if event.src_path == ".\\test.log":            # how to get append content from the logif __name__ == "__main__":    event_handler = MyHandler()    observer = Observer()    observer.schedule(event_handler, path='.', recursive=False)    observer.start()    try:        while True:            time.sleep(1)    except KeyboardInterrupt:        observer.stop()
查看完整描述

1 回答

?
LEATH

TA貢獻(xiàn)1936條經(jīng)驗(yàn) 獲得超7個(gè)贊

據(jù)我所知Watchdog,僅通知文件是否已修改,但它不會(huì)提供更改的信息,您必須自行檢查。


我看到了兩種顯示新附加內(nèi)容的方法。


首先:保持打開(kāi)的文件,然后read()將只讀取新內(nèi)容。


我的處理程序獲取文件名作為參數(shù)以在啟動(dòng)時(shí)打開(kāi)它并始終保持打開(kāi)狀態(tài)。


在__init__您可以使用read()跳過(guò)現(xiàn)有內(nèi)容


import os

import time

from watchdog.observers import Observer

from watchdog.events import FileSystemEventHandler



class AppendEventHandler(FileSystemEventHandler):


    def __init__(self, path):

        self.path = path

        self.fh = open(path)

        self.fh.read() # skip existing content


    def on_modified(self, event):

        if event.src_path == self.path:

            print(self.fh.read())


if __name__ == "__main__":

    event_handler = AppendEventHandler(".\\test.log")


    observer = Observer()

    observer.schedule(event_handler, ".", recursive=True)

    observer.start()


    try:

        while True:

            time.sleep(1)

    except KeyboardInterrupt:

        observer.stop()

    observer.join()

第二:如果您不想保留打開(kāi)的文件,那么您可以記住它的大小并fh.seek(previous_size)在附加內(nèi)容開(kāi)始時(shí)使用它來(lái)開(kāi)始閱讀。


import os

import time

from watchdog.observers import Observer

from watchdog.events import FileSystemEventHandler



class AppendEventHandler(FileSystemEventHandler):


    def __init__(self, path):

        self.path = path

        self.size = os.stat(path).st_size # remeber previous size


    def on_modified(self, event):

        if event.src_path == self.path:

            new_size = os.stat(self.path).st_size # get new size 

            if new_size > self.size: 

                fh = open(self.path)

                fh.seek(self.size) # move to appended content (move to end of old content)

                print(fh.read())

                fh.close()

                self.size = new_size # remeber new size        


if __name__ == "__main__":

    event_handler = AppendEventHandler("./test.log")


    observer = Observer()

    observer.schedule(event_handler, ".", recursive=True)

    observer.start()


    try:

        while True:

            time.sleep(1)

    except KeyboardInterrupt:

        observer.stop()

    observer.join()


查看完整回答
反對(duì) 回復(fù) 2022-06-02
  • 1 回答
  • 0 關(guān)注
  • 101 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)