如何使用AND运算符?

时间:2012-07-20 14:58:57

标签: c# regex

如何在C#中使用正则表达式匹配句子中的多个字符串?
例如,在下面的句子中,我想检查字符串L - VDom是否存在。

  

L - V 8:30到22:00。 Sab y Dom..11:00 22:00。

我在Regex中遇到AND运算符问题。

Regex.IsMatch(hours, @"\bL - V\b.*?\Dom\b")

有什么想法吗?

由于

6 个答案:

答案 0 :(得分:3)

您可以将其作为单个正则表达式执行,例如/L - V.*Dom/,也可以执行两个匹配和一个和。

答案 1 :(得分:2)

使用两个单独的正则表达式(或仅the String.indexOf(String) method)和C#的常规&&运算符可能更为明确;但是如果你想把它放到一个正则表达式中,那么你可以写下以下任何一个:

L - V.*Dom                <-- if `L - V` will always come before `Dom`
(L - V.*Dom|Dom.*L - V)   <-- if you don't know which will come first

.表示“除换行符之外的任何字符”,因此.*表示“零或多个非换行符”,即“任何不包含换行符的子字符串”。)

答案 2 :(得分:2)

可以简单地完成

using System;
using System.Text.RegularExpressions;

namespace ConsoleApplication1
{
  class Program
  {
    static void Main(string[] args)
    {
      string txt="L - V 8:30 a 22:00 hrs. Sab y Dom..11:00 a 22:00 hrs.";

      string re1="(L)"; // Any Single Character 1
      string re2=".*?"; // Non-greedy match on filler
      string re3="(-)"; // Any Single Character 2
      string re4=".*?"; // Non-greedy match on filler
      string re5="(V)"; // Any Single Character 3
      string re6=".*?"; // Non-greedy match on filler
      string re7="(Dom)";   // Word 1

      Regex r = new Regex(re1+re2+re3+re4+re5+re6+re7,RegexOptions.IgnoreCase|RegexOptions.Singleline);
      Match m = r.Match(txt);
      if (m.Success)
      {
            String c1=m.Groups[1].ToString();
            String c2=m.Groups[2].ToString();
            String c3=m.Groups[3].ToString();
            String word1=m.Groups[4].ToString();
            Console.Write("("+c1.ToString()+")"+"("+c2.ToString()+")"+"("+c3.ToString()+")"+"("+word1.ToString()+")"+"\n");
      }
      Console.ReadLine();
    }
  }
}

答案 3 :(得分:2)

如果您想使用正则表达式,请尝试:

bool isMatch = Regex.IsMatch(hours, @"^\bL - V\b.*?\Dom.*$");

但你也可以说

bool isMatch = hours.IndexOf("L - V") != -1 && hours.IndexOf("Dom") != -1

也许没有正则表达式甚至更简单,在我看来,如果没有正则表达式可以完成某些事情,那么在没有正则表达式的情况下完成它。也许在这种情况下,如果你想要更宽容,例如匹配L-VL- V值得使用正则表达式(但我们需要修改表达式)。

答案 4 :(得分:2)

RegEx的默认行为是将术语与AND结合起来。你的表达几乎是正确的,除了“Dom”的“D”之前的反斜杠。您还可以在“Dom”之前附加“\ b”以便仅查找整个单词。还有“?”如果您只想检查模式是否存在,则没有任何区别。

\bL - V\b.*\bDom\b

如果字符串应包含“L - V”或“Dom”,则表达式为

\b(L - V|Dom)\b

如果找到整个单词并不重要,可以在两个表达式中删除“\ b”    ("L - V.*Dom" resp。"L - V|Dom")或仅使用

执行此操作
hours.Contains("L - V") && hours.Contains("Dom")

答案 5 :(得分:1)

好吧,你的正则表达式返回true,所以我不确定你为什么遇到问题。话虽如此,正则表达式在这里似乎有点过分,特别是如果你不知道哪个字符串首先出现。我可能会这样做:

var haystack = "L - V 8:30 a 22:00 hrs. Sab y Dom..11:00 a 22:00 hrs.";
if (new List<string> { "L - V", "Dom" }.TrueForAll(needle => haystack.Contains(needle))) 
{
  ///stuff
}