分享一个Python 写的监控日志log txt文档 的代码

监控log文件的需求

某些特殊原因,想一直看到.log 的最后一行打印,所以写了一些代码监控log

(有个奇怪需求,就是log 因为重复启动原因,会一直加,不是同一个log)

监控界面

涉及的Python代码,

有需要的拿去吧

  • 时间戳
  • unicode - 没用上(python 3)
  • 文件夹遍历
  • 读取文件夹
  • enumerate() 方法
  • while 循环 +sleep(1)
python 复制代码
# 相关的Renderdoc 关于glsl shader的逆向代码 ,非Python:https://blog.csdn.net/avi9111/article/details/132798279?spm=1001.2014.3001.5502
# Notices:
# 1. the 3rd parameter of open() is to disable file buffering
#      so file updated by another process could be picked up correctly
#      but since your focus is newly added tail, enable buffering is ok too
# 2. It is not necessary to fh.tell() to save the position, and then seek()
#     to resume, as if readline() failed, the pointer stay still at the EOF

import sys
import time
import os
if sys.version_info[0] >= 3:
    unicode = str
'''获取文件的创建时间'''
#模型奇妙 https://www.cnpython.com/qa/153573
def get_FileCreateTime(filePath):
    #filePath = unicode(filePath,encoding='utf8')#Python 3 renamed the unicode type to str,
    t = os.path.getctime(filePath)
    #return TimeStampToTime(t)
    return t
#获取文件内容(info),参考:https://blog.csdn.net/HeatDeath/article/details/79526037
def checkLatestLog(folder):
    files = os.listdir(folder)
    
    name_latest = ''
    t_latest = -1
    for i,n in enumerate(files):#这个 i 没什么用,就是写着玩
        t = get_FileCreateTime(folder+"\\" + n)#这个拼接代码应该在 win 平台,才能用
        if t>t_latest:
            t_latest = t
            name_latest = n
    return folder +"\\" + name_latest#这个代码应该在 win 平台,才能用
        
filename = sys.argv[1]#全路径吧,(要是相对路径。。。本来可以,现在应该会有问题 ,下面套了逻辑)
print("...open..."+filename)
thisFilePath= filename
#就是一个很普通的update 循环,也可以不用 with open() 套外面,不过之前代码就是这个逻辑
with open(filename) as fh:
#with open(filename, 'r', 0) as fh:
#with os.fdopen(filename,'wb',0) as fh:
    while True: 
        line = fh.readline()
        if not line:
            time.sleep(1)
            # 加了一个逻辑==判断当前文件夹是否有最新日志
            logFilePath = checkLatestLog(os.path.dirname(filename))
            if(logFilePath!=thisFilePath):
                fh = open(logFilePath)
                thisFilePath = logFilePath
                print(".............. 换了一个 log .............." + logFilePath)

        else:
            print(line)
相关推荐
带娃的IT创业者3 小时前
Python 异步编程完全指南:从入门到精通
服务器·开发语言·python·最佳实践·asyncio·异步编程
一只鹿鹿鹿5 小时前
信息安全等级保护安全建设防护解决方案(总体资料)
运维·开发语言·数据库·面试·职场和发展
喵叔哟5 小时前
9. 【Blazor全栈开发实战指南】--Blazor调用JavaScript
开发语言·javascript·udp
wuqingshun3141596 小时前
如何停止一个正在退出的线程
java·开发语言·jvm
我命由我123456 小时前
Element Plus - Form 的 resetField 方法观察记录
开发语言·前端·javascript·vue.js·html·html5·js
朱包林6 小时前
Python基础
linux·开发语言·ide·python·visualstudio·github·visual studio
Eward-an6 小时前
【算法竞赛/大厂面试】盛最多水容器的最大面积解析
python·算法·leetcode·面试·职场和发展
no_work6 小时前
基于python预测含MLP决策树LGBM随机森林XGBoost等
python·决策树·随机森林·cnn
进击的雷神6 小时前
地址语义解析、多语言国家匹配、动态重试机制、混合内容提取——德国FAKUMA展爬虫四大技术难关攻克纪实
爬虫·python
FreakStudio6 小时前
一行命令搞定驱动安装!MicroPython 开发有了自己的 “PyPI”包管理平台!
python·stm32·单片机·嵌入式·arm·电子diy