【问题标题】:Log parsing using RegEx使用 RegEx 进行日志解析
【发布时间】:2020-06-04 12:32:53
【问题描述】:

我想在特定类中解析以下日志。

2019-11-14T04:24:04.072Z INFO MessagingObjectFactoryImpl-4-2 ExporterLastAckServiceImpl - - [nsx@6876 comp="nsx-manager" level="INFO" subcomp="manager"] Found exporter with elaId = Node#a3844284-e626-11e9-a87b-005056bcc0c6#AggSvc-L2-Bridging, returning lastAck = 16507 2019-11-14T04:23:08.362Z INFO ActivityEventRecovery-1 ActivityCacheManager - - [nsx@6876 comp="nsx-manager" level="INFO" subcomp="manager"] Handling activity 92d6a146-fa12-4889-a0ff-441087e047d0 completion event for 1 2019-11-14T04:23:08.362Z DEBUG ActivityEventRecovery-1 ActivityCacheManager - - [nsx@6876 comp="nsx-manager" level="INFO" subcomp="manager"] Handling activity 92d6a146-fa12-4889-a0ff-441087e047d0 completion event for 1

我试过了

(?<timestamp>\d\d\d\d-\d\d-\d\dT\d\d:\d\d:\d\d.\d\d\dZ)\s+(?<level>INFO|WARN|DEBUG|ERROR|FATAL|TRACE)\s+(?<text>.*?\s.*?)\-\s+\-\s\[(?<class>.*?)\]\s+(?<Message>.*? |\Z)

我得到了除了 Message 类之外的所有东西。 我应该如何编写消息类正则表达式。 请回答。 这是链接https://regex101.com/r/LJnVrS/86

【问题讨论】:

    标签: python regex logging logparser


    【解决方案1】:

    .*? 将匹配尽可能少的字符,直到出现空格。因为看起来匹配都在行尾结束,相反,只要继续匹配,直到你到达行尾。删除s 标志,并使用:

    (?<Message>.*)
    

    (不需要\Z

    https://regex101.com/r/LJnVrS/87

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2020-09-13
      • 2012-04-20
      • 1970-01-01
      • 2015-09-06
      • 2018-07-30
      • 2012-05-11
      • 1970-01-01
      相关资源
      最近更新 更多