1

我正在学习正则表达式,但仍然很难学习。
所以我的问题是这样的,我给出了一组关键字:

敏捷的棕色狐狸

我必须在一堆句子中找到,例如:

布朗性感狐狸在后院跳得那么快……

如果与这些单词有任何匹配(不区分大小写):

The, the, brown, Brown, fox, Fox, quick, Quick

然后我可以说返回值是true

如何在正则表达式中做到这一点?我正在考虑拆分单词并放入数组并使用循环并找到它们,.Contains(...)但我知道这并不理想。

其实我还有一个担心。但我害怕把它作为一个新问题发布。
所以我的第二个问题是,正则表达式如何读取模式?优先事项和最低优先事项是什么?
无论如何,请帮助我解决我的问题。

编辑

抱歉回复晚了,但@PatrikW 的解决方案似乎不起作用。
我有静态类:

    public static bool ValidateRegex(string value, string regex)
    {
        value += ""; // Fail safe for null
        Regex obj = new Regex(regex, RegexOptions.IgnoreCase);
        if (value.Trim() == "")
            return false;
        else
        {
            return obj.IsMatch(value);
        }
    }  

构造正则表达式模式:

keyword = "maria";
            string regexPattern = "(?<=\b)(";
            string Or = string.Empty;

            foreach (string item in keyword.Split(new char[] { ' ', ',', '.' }, StringSplitOptions.RemoveEmptyEntries).ToList())
            {
                regexPattern += Or + "(" + item + ")";
                Or = "|";
            }

            regexPattern += ")(?=\b)";  

数据信息:

List<Friend> useritems = null;
useritems = ((List<Friend>)SessonHandler.Data.FriendList).Where(i =>
    Utility.ValidateRegex(i.LastName, regexPattern) ||
    Utility.ValidateRegex(i.FirstName, regexPattern) ||
    Utility.ValidateRegex(i.MiddleName, regexPattern)).ToList();

//regexPattern = "(?<=\b)((maria))(?=\b)"
//LastName = "MARIA CALIBRI"
//FirstName = "ALICE"
//MiddleName = null  

可能是我对代码做错了什么。请帮忙。

编辑 2
我忘记了@标志。这现在必须工作:

string regexPattern = @"(?<=\b)(";
.
.
.
regexPattern += @")(?=\b)";  

下面的答案是正确的。

4

1 回答 1

4

Felice 展示的是更动态的解决方案,但这里有一个模式可以找到您所拥有的确切关键字:

"(?<=\b)((The)|(quick)|(brown)|(fox))(?=\b)"

由于前导和尾随捕获组,它只会匹配整个单词而不是其中的一部分。

这是一个例子:

Regex foxey = new Regex(@"(?<=\b)((The)|(quick)|(brown)|(fox))(?=\b)");
foxey.Options = RegexOptions.IgnoreCase;
bool doesMatch = foxey.IsMatching("the Brown SexyFox Jumps soQuickly in the backyard...");

编辑 - 正则表达式引擎:

简而言之,正则表达式引擎一次遍历输入字符串一个字符,从最左边的一个字符开始,将其与我们编写的正则表达式模式的第一部分进行检查。如果匹配,解析器将移动到下一个字符并根据模式的下一部分检查它。如果它成功地遍历了整个模式,那就是匹配。

您可以通过搜索“正则表达式引擎”或类似的内容来了解​​正则表达式的内部工作原理。这是一个选择: http ://www.regular-expressions.info/engine.html

于 2012-10-03T12:45:48.157 回答