我正在尝试为字符串匹配,但只有当该字符串后面没有冒号和一些数字时才会匹配。
我已经达到:(?<=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 .....)之后是一个时间,我不希望它完全被击中。
答案 0 :(得分:0)
也许这个正则表达式可能是一个选项:
<强>解释强>
(?<=
[A-Z]\d+:
\w+
(或[a-zA-Z\d]+
)一次或多次(?=\D+ )
或者您可以使用(?<=REQUEST:V4:)\w+(?=\D+ )