我试图在Spiceworks中运行regex来解析电子邮件头,以选择用于票务分配的时间的第一个实例。正则表达式本身工作,但它获取所有时间实例,而不仅仅是一个.。
下面是正则表达式:\.*(0[1]|1[3-7]):\d\d:\d\d
我试图通过这样做来达到非贪婪的目的:\.*?(0[1]|1[3-7]):\d\d:\d\d
,但这似乎行不通。把问号放在量词前面并没有为此做任何事情。
什么是一个好的解决方案,使这个正则表达式不贪婪或只拿起第一个实例?
谢谢,
安德鲁N.
编辑:我试图从正则表达式中获得的是"13:04:57“这样的内容,而不是整个日期。
示例字符串:通过SMTP id co5csp22954317qdb接收: 127.0.0.1;Wed,2015年5月6日13:02:22-0700 (PDT) X-接收: 127.0.0.1与SMTP id j185mr26699743oig.68.1430928141923;Wed,2015年5月6日13:02:21 -0700 (PDT)
发布于 2015-06-04 17:15:05
您可以使用这个基于展望的正则表达式来匹配由regex匹配的时间的第一个实例:
/^(?:(?!(?:0[1]|1[3-7]):\d\d:\d\d).)*((?:0[1]|1[3-7]):\d\d:\d\d)/m
(?!...)
是一种负前瞻性,它确保在匹配时间之前没有其他时间实例,因此只匹配第一个实例。
发布于 2015-06-04 16:16:16
{1}匹配以前的模式1次。如果你张贴一个示例头,我可以测试REGEX,以确保我得到的一切都正确。试试看以下几点。
(.*(0[1]|1[3-7]):\d\d:\d\d){1}
https://stackoverflow.com/questions/30648972
复制相似问题