假设我有一个这样的多行字符串:
STARTFRUIT
banana
ENDFRUIT
STARTFRUIT
avocado
ENDFRUIT
STARTVEGGIE
rhubarb
ENDVEGGIE
STARTFRUIT
lime
ENDFRUIT
我想搜寻所有水果,没有蔬菜。我试试这个:
MatchCollection myMatches = Regex.Matches(tbBlob.Text, "STARTFRUIT.*ENDFRUIT", RegexOptions.Singleline);
foreach (var myMatch in myMatches)
{
Forms.MessageBox.Show(String.Format("Match: {0}", myMatch), "Match", Forms.MessageBoxButtons.OK, Forms.MessageBoxIcon.Information);
}
问题是,它给了我一个包含第一个STARTFRUIT和开头以及最后一个ENDFRUIT的大匹配,而不是给我一个三个匹配的数组。有没有办法“最小化”匹配搜索?我在RegexOptions
中没有看到任何帮助。
答案 0 :(得分:22)
在量词之后使用non-greedy modifier(问号):
"STARTFRUIT.*?ENDFRUIT" ^ add this
请注意,这里的问号与使用量词时的含义不同,它表示“匹配零或一”。