[英]optional groups in regex to match different lines
我有两个文件:
/c/desktop/test.txt#edit
/c/desktop/test.txt
我正在使用正则表达式: (.*desktop.*)(?:#.*)?
它应该匹配desktop
之前和之后的所有内容,但保留来自#
的任何内容,该行中可能存在也可能不存在。
但它要么匹配所有内容,要么什么都不匹配。
实现您想要的一种方法是使用非贪婪运算符*?
与行尾运算符一起使用: (.*desktop.*?)(?:$|#.*)
.*?
表示匹配尽可能少的字符$|#.*
表示匹配行尾或#
后跟字符。 这样,第一组中的.*
不会匹配#
之后的内容,因为如果第二组接受它,则可以匹配具有更少字符的模式。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.