我需要从字符串中提取包含在两个分隔符之间的一组字符,而不返回分隔符本身。

一个简单的例子应该会有所帮助:

目标:提取方括号之间的子字符串,不返回方括号本身。

基本字符串:这是一个测试字符串[或多或少]

如果我使用下面的reg。前女友。

\[.*?\]

比赛[差不多]进行得很顺利。我只需要得到更多或更少(没有括号)。

有可能做到吗?


当前回答

[^\[]匹配任何不是[的字符。

+匹配1个或更多不是[的东西。创建这些匹配项的组。

(?=\])正面展望]。匹配以]结尾的组,但不将其包含在结果中。

完成了。

[^\[]+(?=\])

证明。

http://regexr.com/3gobr

类似于由null提出的解决方案。但额外的\]是不需要的。另外需要注意的是,\似乎不需要转义^后面的[。为了可读性,我会保留它。

在分隔符相同的情况下不起作用。例如“more or less”。

其他回答

如果需要提取不带括号的文本,可以使用bash awk

echo[你好mundo”|啊- f”[][]{打印2美元的”

结果:

你好世界

我想在/和#之间找到一个字符串,但#有时是可选的。下面是我使用的正则表达式:

  (?<=\/)([^#]+)(?=#*)

PHP:

$string ='This is the match [more or less]';
preg_match('#\[(.*)\]#', $string, $match);
var_dump($match[1]);

去掉[]的用法:

\[.+\]

您只需要“捕获”括号之间的位。

\[(.*?)\]

为了捕获,你把它放在括号里。你没有说它使用的是哪种语言。例如,在Perl中,您可以使用$1变量来访问它。

my $string ='This is the match [more or less]';
$string =~ /\[(.*?)\]/;
print "match:$1\n";

其他语言将有不同的机制。例如,我相信c#使用Match集合类。