MatchCollection.Count Свойство

Определение

Получает количество соответствий.Gets the number of matches.

public:
 property int Count { int get(); };
public int Count { get; }
member this.Count : int
Public ReadOnly Property Count As Integer

Значение свойства

Количество соответствий.The number of matches.

Реализации

Исключения

Время ожидания истекло.A time-out occurred.

Примеры

В следующем примере Count свойство используется для определения того, найден ли вызов Regex.Matches(String, String) метода с любым совпадением.The following example uses the Count property to determine whether the call to the Regex.Matches(String, String) method found any matches. В противном случае это означает, что совпадения не найдены.If not, it indicates that no matches were found. В противном случае он перечисляет совпадения и отображает их значение и точку во входной строке, в которой они были найдены.Otherwise, it enumerates the matches and displays their value and the position in the input string at which they were found.

using System;
using System.Text.RegularExpressions;

public class Example
{
   public static void Main()
   {
      string pattern = @"\d+";
      string[] inputs = { "This sentence contains no numbers.",
                          "123 What do I see?",
                          "2468 369 48 5" };
      foreach (var input in inputs) {
         MatchCollection matches = Regex.Matches(input, pattern);
         Console.WriteLine("Input: {0}", input);
         if (matches.Count == 0)
            Console.WriteLine("   No matches");
         else
            foreach (Match m in matches)
               Console.WriteLine("   {0} at index {1}", m.Value, m.Index);

         Console.WriteLine();
      }
   }
}
// The example displays the following output:
//       Input: This sentence contains no numbers.
//          No matches
//
//       Input: 123 What do I see?
//          123 at index 0
//
//       Input: 2468 369 48 5
//          2468 at index 0
//          369 at index 5
//          48 at index 9
//          5 at index 12
Imports System.Text.RegularExpressions

Module Example
   Public Sub Main()
      Dim pattern As String = "\d+"
      Dim inputs() As String = { "This sentence contains no numbers.",
                                 "123 What do I see?",
                                 "2468 369 48 5" }
      For Each inputStr In inputs
         Dim matches As MatchCollection = Regex.Matches(inputStr, pattern)
         Console.WriteLine("Input: {0}", inputStr)
         If matches.Count = 0
            Console.WriteLine("   No matches")
         Else
            For Each m As Match In matches
               Console.WriteLine("   {0} at index {1}", m.Value, m.Index)
            Next
         End If
         Console.WriteLine()
      Next
   End Sub
End Module
' The example displays the following output:
'       Input: This sentence contains no numbers.
'       No matches
'
'       Input: 123 What do I see?
'       123 at index 0
'
'       Input: 2468 369 48 5
'       2468 at index 0
'       369 at index 5
'       48 at index 9
'       5 at index 12

Шаблон \d+ регулярного выражения соответствует одному или нескольким десятичным символам во входной строке.The regular expression pattern \d+ matches one or more decimal characters in an input string.

Комментарии

Получение доступа к отдельным членам MatchCollection объекта путем получения значения Count свойства коллекции заставляет обработчик регулярных выражений заполнить коллекцию с помощью прямого вычисления.Accessing individual members of the MatchCollection object by retrieving the value of the collection's Count property causes the regular expression engine to populate the collection using direct evaluation. Функция LN контраста, GetEnumerator вызов метода (или foreach использование оператора в C# и For Each... Next инструкция в Visual Basic) заставляет обработчик регулярных выражений заполнять коллекцию по мере необходимости с помощью отложенного вычисления.ln contrast, calling the GetEnumerator method (or using the foreach statement in C# and the For Each...Next statement in Visual Basic) causes the regular expression engine to populate the collection on an as needed basis using lazy evaluation. Прямое вычисление может оказаться гораздо более дорогостоящим методом создания коллекции, чем ленивое вычисление.Direct evaluation can be a much more expensive method of building the collection than lazy evaluation.

Поскольку объект обычно заполняется с помощью отложенного вычисления, попытка определить число элементов в коллекции до его полного заполнения может RegexMatchTimeoutException вызвать исключение. MatchCollectionBecause the MatchCollection object is generally populated by using lazy evaluation, trying to determine the number of elements in the collection before it has been fully populated may throw a RegexMatchTimeoutException exception. Это исключение может быть выдано, если действует значение времени ожидания для операций сопоставления, и попытка найти одно совпадение превышает этот интервал времени ожидания.This exception can be thrown if a time-out value for matching operations is in effect, and the attempt to find a single match exceeds that time-out interval.

Применяется к