首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >寻找时间的Regex不想不贪婪

寻找时间的Regex不想不贪婪
EN

Stack Overflow用户
提问于 2015-06-04 16:12:43
回答 2查看 38关注 0票数 1

我试图在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)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-06-04 17:15:05

您可以使用这个基于展望的正则表达式来匹配由regex匹配的时间的第一个实例:

代码语言:javascript
运行
复制
/^(?:(?!(?:0[1]|1[3-7]):\d\d:\d\d).)*((?:0[1]|1[3-7]):\d\d:\d\d)/m

(?!...)是一种负前瞻性,它确保在匹配时间之前没有其他时间实例,因此只匹配第一个实例。

RegEx演示

票数 1
EN

Stack Overflow用户

发布于 2015-06-04 16:16:16

{1}匹配以前的模式1次。如果你张贴一个示例头,我可以测试REGEX,以确保我得到的一切都正确。试试看以下几点。

代码语言:javascript
运行
复制
(.*(0[1]|1[3-7]):\d\d:\d\d){1}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30648972

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档