Capture.Value Propriedade

Definição

Obtém a substring capturada da string de entrada.

public:
 property System::String ^ Value { System::String ^ get(); };
public string Value { get; }
member this.Value : string
Public ReadOnly Property Value As String

Valor de Propriedade

A substring que é capturada pelo match.

Exemplos

O exemplo seguinte define uma expressão regular que corresponde a frases que não contêm pontuação exceto por um ponto ("."). A Match.Value propriedade mostra a cadeia de resultados, que consiste numa frase correspondente, para cada correspondência. A Group.Value propriedade mostra a cadeia de resultados para cada grupo capturador; consiste na última cadeia capturada por esse grupo capturador. A Capture.Value propriedade mostra a cadeia de resultados para cada captura.

using System;
using System.Text.RegularExpressions;

public class Example
{
   public static void Main()
   {
      string input = "Yes. This dog is very friendly.";
      string pattern = @"((\w+)[\s.])+";
      foreach (Match match in Regex.Matches(input, pattern))
      {
         Console.WriteLine("Match: {0}", match.Value);
         for (int groupCtr = 0; groupCtr < match.Groups.Count; groupCtr++)
         {
            Group group = match.Groups[groupCtr];
            Console.WriteLine("   Group {0}: {1}", groupCtr, group.Value);
            for (int captureCtr = 0; captureCtr < group.Captures.Count; captureCtr++)
               Console.WriteLine("      Capture {0}: {1}", captureCtr, 
                                 group.Captures[captureCtr].Value);
         }                      
      }
   }
}
// The example displays the following output:
//       Match: Yes.
//          Group 0: Yes.
//             Capture 0: Yes.
//          Group 1: Yes.
//             Capture 0: Yes.
//          Group 2: Yes
//             Capture 0: Yes
//       Match: This dog is very friendly.
//          Group 0: This dog is very friendly.
//             Capture 0: This dog is very friendly.
//          Group 1: friendly.
//             Capture 0: This
//             Capture 1: dog
//             Capture 2: is
//             Capture 3: very
//             Capture 4: friendly.
//          Group 2: friendly
//             Capture 0: This
//             Capture 1: dog
//             Capture 2: is
//             Capture 3: very
//             Capture 4: friendly
Imports System.Text.RegularExpressions

Module Example
   Public Sub Main()
      Dim input As String = "Yes. This dog is very friendly."
      Dim pattern As String = "((\w+)[\s.])+"
      For Each match As Match In Regex.Matches(input, pattern)
         Console.WriteLine("Match: {0}", match.Value)
         For groupCtr As Integer = 0 To match.Groups.Count - 1
            Dim group As Group = match.Groups(groupCtr)
            Console.WriteLine("   Group {0}: {1}", groupCtr, group.Value)
            For captureCtr As Integer = 0 To group.Captures.Count - 1
               Console.WriteLine("      Capture {0}: {1}", captureCtr, _
                                 group.Captures(captureCtr).Value)
            Next
         Next                      
      Next
   End Sub
End Module
' The example displays the following output:
'       Match: Yes.
'          Group 0: Yes.
'             Capture 0: Yes.
'          Group 1: Yes.
'             Capture 0: Yes.
'          Group 2: Yes
'             Capture 0: Yes
'       Match: This dog is very friendly.
'          Group 0: This dog is very friendly.
'             Capture 0: This dog is very friendly.
'          Group 1: friendly.
'             Capture 0: This
'             Capture 1: dog
'             Capture 2: is
'             Capture 3: very
'             Capture 4: friendly.
'          Group 2: friendly
'             Capture 0: This
'             Capture 1: dog
'             Capture 2: is
'             Capture 3: very
'             Capture 4: friendly

O padrão ((\w+)[\s.])+ de expressão regular é definido conforme mostrado na tabela a seguir. Note-se que nesta expressão regular, um quantificador (+) é aplicado a toda a expressão regular.

Pattern Description
(\w+) Combinar um ou mais caracteres de palavra. Este é o segundo grupo de captura.
[\s.]) Corresponder a um carácter ou ponto em branco (".").
((\w+)[\s.]) Compare um ou mais caracteres de palavra seguidos por um espaço em branco ou ponto ("."). Este é o primeiro grupo de captura.
((\w+)[\s.])+ Compare uma ou mais ocorrências de um ou mais caracteres de palavra seguidas por um espaço em branco ou ponto (".").

Neste exemplo, a cadeia de entrada consiste em duas frases. Como mostra o resultado, a primeira frase consiste apenas numa palavra, pelo que o CaptureCollection objeto tem um único Capture objeto que representa a mesma captura que o Group objeto. A segunda frase consiste em várias palavras, pelo que os Group objetos contêm apenas informação sobre a última subexpressão correspondente. O Grupo 1, que representa a primeira captura, contém a última palavra da frase que tem um período de encerramento. O Grupo 2, que representa a segunda captura, contém a última palavra da frase. No entanto, os Capture objetos no objeto do CaptureCollection grupo capturam cada correspondência de subexpressão. Os Capture objetos da coleção de capturas do primeiro grupo de captura contêm informação sobre cada palavra capturada e cada carácter ou período de espaço em branco. Os Capture objetos da coleção de capturas do segundo grupo de captura contêm informação sobre cada palavra capturada.

O exemplo seguinte utiliza um padrão de expressão regular, ^([a-z]+)(\d+)*\.([a-z]+(\d)*)$, para corresponder a um número de produto que consiste em duas partes separadas por um período. Ambas as partes consistem em caracteres alfabéticos seguidos de números opcionais. Como a primeira cadeia de entrada não corresponde ao padrão, o valor da propriedade do Value objeto devolvido System.Text.RegularExpressions.Match é String.Empty. De forma semelhante, quando o padrão de expressão regular não consegue corresponder a um grupo capturador, o valor da propriedade do Value objeto correspondente Group é String.Empty.

using System;
using System.Text.RegularExpressions;

public class Example
{
   public static void Main()
   {
      String pattern = @"^([a-z]+)(\d+)?\.([a-z]+(\d)*)$";
      String[] values = { "AC10", "Za203.CYM", "XYZ.CoA", "ABC.x170" };   
      foreach (var value in values) {
         Match m = Regex.Match(value, pattern, RegexOptions.IgnoreCase);
         if (m.Success) {
            Console.WriteLine("Match: '{0}'", m.Value);
            Console.WriteLine("   Number of Capturing Groups: {0}", 
                              m.Groups.Count);
            for (int gCtr = 0; gCtr < m.Groups.Count; gCtr++) {
               Group group = m.Groups[gCtr];
               Console.WriteLine("      Group {0}: {1}", gCtr, 
                                 group.Value == "" ? "<empty>" : "'" + group.Value + "'");   
               Console.WriteLine("         Number of Captures: {0}", 
                                 group.Captures.Count);
           
               for (int cCtr = 0; cCtr < group.Captures.Count; cCtr++) 
                  Console.WriteLine("            Capture {0}: {1}", 
                                    cCtr, group.Captures[cCtr].Value);
            }
         } 
         else {
            Console.WriteLine("No match for {0}: Match.Value is {1}", 
                              value, m.Value == String.Empty ? "<empty>" : m.Value);
         }
      }
   }
}
// The example displays the following output:
//       No match for AC10: Match.Value is <empty>
//       Match: 'Za203.CYM'
//          Number of Capturing Groups: 5
//             Group 0: 'Za203.CYM'
//                Number of Captures: 1
//                   Capture 0: Za203.CYM
//             Group 1: 'Za'
//                Number of Captures: 1
//                   Capture 0: Za
//             Group 2: '203'
//                Number of Captures: 1
//                   Capture 0: 203
//             Group 3: 'CYM'
//                Number of Captures: 1
//                   Capture 0: CYM
//             Group 4: <empty>
//                Number of Captures: 0
//       Match: 'XYZ.CoA'
//          Number of Capturing Groups: 5
//             Group 0: 'XYZ.CoA'
//                Number of Captures: 1
//                   Capture 0: XYZ.CoA
//             Group 1: 'XYZ'
//                Number of Captures: 1
//                   Capture 0: XYZ
//             Group 2: <empty>
//                Number of Captures: 0
//             Group 3: 'CoA'
//                Number of Captures: 1
//                   Capture 0: CoA
//             Group 4: <empty>
//                Number of Captures: 0
//       Match: 'ABC.x170'
//          Number of Capturing Groups: 5
//             Group 0: 'ABC.x170'
//                Number of Captures: 1
//                   Capture 0: ABC.x170
//             Group 1: 'ABC'
//                Number of Captures: 1
//                   Capture 0: ABC
//             Group 2: <empty>
//                Number of Captures: 0
//             Group 3: 'x170'
//                Number of Captures: 1
//                   Capture 0: x170
//             Group 4: '0'
//                Number of Captures: 3
//                   Capture 0: 1
//                   Capture 1: 7
//                   Capture 2: 0
Imports System.Text.RegularExpressions

Module Example
   Public Sub Main()
      Dim pattern As String = "^([a-z]+)(\d+)?\.([a-z]+(\d)*)$"
      Dim values() As String = { "AC10", "Za203.CYM", "XYZ.CoA", "ABC.x170" }   
      For Each value In values
         Dim m As Match = Regex.Match(value, pattern, RegexOptions.IgnoreCase)
         If m.Success Then
            Console.WriteLine("Match: '{0}'", m.Value)
            Console.WriteLine("   Number of Capturing Groups: {0}", 
                              m.Groups.Count)
            For gCtr As Integer = 0 To m.Groups.Count - 1
               Dim group As Group = m.Groups(gCtr)
               Console.WriteLine("      Group {0}: {1}", gCtr, 
                                 If(group.Value = "", "<empty>", "'" + group.Value + "'"))   
               Console.WriteLine("         Number of Captures: {0}", 
                                 group.Captures.Count)
           
               For cCtr As Integer = 0 To group.Captures.Count - 1
                  Console.WriteLine("            Capture {0}: {1}", 
                                    cCtr, group.Captures(cCtr).Value)
               Next
            Next
         Else
            Console.WriteLine("No match for {0}: Match.Value is {1}", 
                              value, If(m.Value = String.Empty, "<empty>", m.Value))
         End If
      Next    
   End Sub
End Module
' The example displays the following output:
'       No match for AC10: Match.Value is <empty>
'       Match: 'Za203.CYM'
'          Number of Capturing Groups: 5
'             Group 0: 'Za203.CYM'
'                Number of Captures: 1
'                   Capture 0: Za203.CYM
'             Group 1: 'Za'
'                Number of Captures: 1
'                   Capture 0: Za
'             Group 2: '203'
'                Number of Captures: 1
'                   Capture 0: 203
'             Group 3: 'CYM'
'                Number of Captures: 1
'                   Capture 0: CYM
'             Group 4: <empty>
'                Number of Captures: 0
'       Match: 'XYZ.CoA'
'          Number of Capturing Groups: 5
'             Group 0: 'XYZ.CoA'
'                Number of Captures: 1
'                   Capture 0: XYZ.CoA
'             Group 1: 'XYZ'
'                Number of Captures: 1
'                   Capture 0: XYZ
'             Group 2: <empty>
'                Number of Captures: 0
'             Group 3: 'CoA'
'                Number of Captures: 1
'                   Capture 0: CoA
'             Group 4: <empty>
'                Number of Captures: 0
'       Match: 'ABC.x170'
'          Number of Capturing Groups: 5
'             Group 0: 'ABC.x170'
'                Number of Captures: 1
'                   Capture 0: ABC.x170
'             Group 1: 'ABC'
'                Number of Captures: 1
'                   Capture 0: ABC
'             Group 2: <empty>
'                Number of Captures: 0
'             Group 3: 'x170'
'                Number of Captures: 1
'                   Capture 0: x170
'             Group 4: '0'
'                Number of Captures: 3
'                   Capture 0: 1
'                   Capture 1: 7
'                   Capture 2: 0

O padrão de expressão regular é definido conforme mostrado na tabela a seguir:

Pattern Description
^ Comece a partida no início da string.
([a-z]+) Compare uma ou mais ocorrências de qualquer personagem de a a z. Como o motor de expressões regulares passa a opção RegexOptions.IgnoreCase , esta comparação é indistinta a maiúsculas e maiúsculas. Este é o primeiro grupo de captura.
(\d+)? Corresponda zero ou uma ocorrência de um ou mais dígitos decimais. Este é o segundo grupo de captura.
\. Combina com uma personagem literal de época.
([a-z]+ Compare uma ou mais ocorrências de qualquer personagem de a a z. A comparação não diferencia maiúsculas de minúsculas.
(\d)* Corresponder a zero ou mais dígitos decimais. Um único dígito correspondente é o quarto grupo a capturar.
([a-z]+(\d)*) Associe um ou mais caracteres alfabéticos de a a z seguidos de zero, um ou mais dígitos decimais. Este é o quarto grupo de captura.
$ Concluir o combate no final da sequência.

Observações

Se uma chamada ao Regex.Match método ou Match.NextMatch não encontrar correspondência, o valor da propriedade devolvida Match.Value é String.Empty. Se o motor de expressões regulares não conseguir corresponder a um grupo de captura. O valor da propriedade devolvida Group.Value é String.Empty. Veja o segundo exemplo para uma ilustração.

Aplica-se a