IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Python 解析log日志 -> 正文阅读

[系统运维]Python 解析log日志

Python 解析log日志

软件环境

软件版本作用
Ubuntu20.04操作系统
python3.8.10python基础环境,提供正则匹配功能
python-dateutil2.8.2日期处理库

环境搭建

在终端命令行输入以下指令

sudo apt install python3.8 # 安装python3
python3.8 -m pip install python-dateutil # 安装 dateutil 包

待解析log日志格式

log日志一般具有时间戳、事件类型、事件产生对象、属性等,本文以具有下列形式的log日志为例

[2021-09-03 11:03:11]************************** EVENT ERROR **************************
[2021-09-03 11:03:11] DevID:  1
[2021-09-03 11:03:11] Attribute:  187

[2021-09-03 11:05:17]************************** EVENT HEART **************************
[2021-09-03 11:05:17] DevID:  1
[2021-09-03 11:05:17] Attribute:  198

[2021-09-03 11:06:20]************************** EVENT HEART **************************
[2021-09-03 11:06:20] DevID:  3
[2021-09-03 11:06:20] Attribute:  14

[2021-09-03 11:10:41]************************** EVENT HEART **************************
[2021-09-03 11:10:41] DevID:  5
[2021-09-03 11:10:41] Attribute:  96

[2021-09-03 11:16:34]************************** EVENT HEART **************************
[2021-09-03 11:16:34] DevID:  1
[2021-09-03 11:16:34] Attribute:  153

log解析脚本

import re
from dateutil.parser import *

DEVID = 1
TAB = "    "

def logparser():
    line_num = 0
	
	# locate EVENT HEART
    pattern_heart = re.compile(r'EVENT HEART')
    # locate xxxx-xx-xx xx:xx:xx
    pattern_timestamp=re.compile(r'[0-9]*-[0-9]*-[0-9]* [0-9]*:[0-9]*:[0-9]*')

    last_time = parse("2021-09-03 00:00:00")
    diff_time = parse("2021-09-03 00:00:00")

    outfile = open("./out.txt", "w+")

    with open("./log.txt") as f:
        lines = f.readlines()
        for line in lines:
            # look for event heart
            result_heart = pattern_heart.findall(line)

            # no heart event in this line
            if not result_heart:   
                line_num = line_num + 1
                continue;

            # 2 is the offset line of Attribute
            if line_num + 2 > len(lines):   
                print("END")
                return;

            # look for DevID, 1 is the offset line of DevID
            DevID = lines[line_num + 1].split(":")[-1].strip()

            # check DevID
            if DevID != str(DEVID):
                line_num = line_num + 1
                continue;

            # 2 is the offset line of Attribute
            Attribute = lines[line_num + 2].split(":")[-1].strip()
            
            # look for string according to regex pattern
            timestamps = pattern_timestamp.findall(line)
            # exist some matches
            if timestamps:
                for timestamp in timestamps:
                    timestamp = parse(timestamp)
                    diff_time = timestamp - last_time
                    last_time = timestamp
                    outfile.write(str(timestamp)+TAB+str(diff_time)+TAB+Attribute+"\n")
                line_num = line_num + 1
            else:
                line_num = line_num + 1
                print("FORMAT ERROR")
                
        f.close()
    outfile.close()

if __name__ == "__main__":
    logparser()
    print("DONE")

解析后文本格式

2021-09-03 11:05:17    11:05:17    198
2021-09-03 11:16:34    0:11:17    153
  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2021-09-14 13:47:18  更:2021-09-14 13:47:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 16:32:31-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码