1

我有下面的代码,它等待日志文件出现,它被外部程序保存在那里,当日志文件出现时,我打开它,而它仍在被写入,并打印内容,因为日志文件是由外部程序更新我想打印出任何写入它的新行。目前我清除打印出来并重新打印整个文本,我想避免这种情况,我只想打印新行。另一件需要改进的事情是等待文件出现,而不是仅仅暂停 python 脚本。

    a=0
    while a <= 10:
        if os.path.isfile(logPath):
            infile = file(logPath)
            break
        a=a+1
        time.sleep(1)
    fileSize1 = 0
    while True:
        wx.Yield()
        fileSize = os.path.getsize(logPath)
        if fileSize > fileSize1:
            lines = infile.readlines()
            log.Clear()
            log.Refresh()
            for line in lines:
                print line.rstrip()
            if "DBG-X: Returning 1" in line:
                break
            if "DBG-X: Returning 0" in line:
                break
        fileSize1 = fileSize
        infile.seek(0)
4

1 回答 1

0

尝试这样的事情......

lastSize = 0
lastLineIndex = 0
while True:
    wx.Yield()
    fileSize = os.path.getsize(logPath)
    if fileSize > lastSize:
        lines = infile.readlines()
        newLines = 0
        for line in lines[lastLineIndex:]:
            newLines += 1
            print line.rstrip()
        lastLineIndex += newLines

        if "DBG-X: Returning 1" in line:
            break
        if "DBG-X: Returning 0" in line:
            break
    fileSize1 = fileSize
    infile.seek(0)

关键是

for line in lines[lastLineIndex:]:

我们跳过我们已经看到的行。您可能可以跳过newLines变量而直接执行,lastLineIndex += 1但我讨厌lastLineIndex在 for 循环内进行更改(我养成了一个习惯以避免其他语言出现问题)

于 2014-02-12T22:22:34.470 回答