匹配字符串,但不是后跟数字

时间:2018-01-28 16:19:09

标签: regex regex-negation regex-lookarounds

我正在尝试为字符串匹配,但只有当该字符串后面没有冒号和一些数字时才会匹配。

我已经达到:(?<=REQUEST:V4:).*\:

(顺便说一下 - 我也想从结果中删掉那个冒号)

这是一些要测试的示例数据:

08:27:08,946 INFO  [com.cars.bdlx.manageinvoice.common.ManageInvoiceService-170] (http-/0.0.0.0:8080-22) REQUEST:V4:dUowlr45NG88:GET_INVOICE_PDF InvoicePdfRequest[customerID=12345678,accountNumber=987654321,invoiceNumber=33333333,countryCode=UK,page=<null>,pageFrom=<null>,pageTo=<null>,copy=false,billingSystemID=MOB,date=<null>,brand=TIGER,callingSystem=Base,userId=777777777,additionalRights=<null>]

08:27:08,244 INFO [TIME-460] (http-/0.0.0.0:8080-7) TIME:V4:YpXGo1j4dMcS:GET_INVOICE_PDF:0.048

基本上第一个应该是命中,而第二个不应该。

在第二个样本中,结果(一个事务ID和一个方法 - GET .....)之后是一个时间,我不希望它完全被击中。

1 个答案:

答案 0 :(得分:0)

也许这个正则表达式可能是一个选项:

(?<=[A-Za-z]\d:)\w+(?=\D+ )

<强>解释

  • 以积极的外观(?<=
  • 断言
  • 之前的是一个字符,后跟一个数字和一个冒号[A-Z]\d+:
  • 匹配任何单词字符\w+(或[a-zA-Z\d]+)一次或多次
  • 以积极向前的方式断言,接下来的内容不是数字一次或多次,后跟空格(?=\D+ )

或者您可以使用(?<=REQUEST:V4:)\w+(?=\D+ )