TimeSpan.ParseExact TimeSpan.ParseExact TimeSpan.ParseExact TimeSpan.ParseExact Method

Definição

Converte a representação da cadeia de caracteres de um intervalo de tempo em seu equivalente TimeSpan.Converts the string representation of a time interval to its TimeSpan equivalent. O formato da representação da cadeia de caracteres deve corresponder exatamente a um formato especificado.The format of the string representation must match a specified format exactly.

Sobrecargas

ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles)

Converte a representação de cadeia de caracteres de um intervalo em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura e estilo.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified format, culture-specific format information, and styles. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.The format of the string representation must match the specified format exactly.

ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles)
ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, as informações de formato específicas de cultura e os estilos.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified formats, culture-specific format information, and styles. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.The format of the string representation must match one of the specified formats exactly.

ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando a matriz de cadeias de caracteres de formato especificada e as informações de formato específicas de cultura.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified array of format strings and culture-specific format information. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.The format of the string representation must match one of the specified formats exactly.

ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider)

Converte a representação de cadeia de caracteres de um intervalo de hora em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura especificadas.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified format and culture-specific format information. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.The format of the string representation must match the specified format exactly.

ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles)

ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles) ParseExact(String, String, IFormatProvider, TimeSpanStyles)

Converte a representação de cadeia de caracteres de um intervalo em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura e estilo.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified format, culture-specific format information, and styles. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.The format of the string representation must match the specified format exactly.

public:
 static TimeSpan ParseExact(System::String ^ input, System::String ^ format, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles);
public static TimeSpan ParseExact (string input, string format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles);
static member ParseExact : string * string * IFormatProvider * System.Globalization.TimeSpanStyles -> TimeSpan
Public Shared Function ParseExact (input As String, format As String, formatProvider As IFormatProvider, styles As TimeSpanStyles) As TimeSpan

Parâmetros

input
String String String String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.A string that specifies the time interval to convert.

format
String String String String

Uma cadeia de caracteres de formato padrão ou personalizada que define o formato obrigatório de input.A standard or custom format string that defines the required format of input.

formatProvider
IFormatProvider IFormatProvider IFormatProvider IFormatProvider

Um objeto que fornece informações de formatação específicas de cultura.An object that provides culture-specific formatting information.

styles
TimeSpanStyles TimeSpanStyles TimeSpanStyles TimeSpanStyles

Uma combinação bit a bit de valores de enumeração que definem os elementos de estilo que podem estar presentes em input.A bitwise combination of enumeration values that defines the style elements that may be present in input.

Retornos

Um intervalo de tempo que corresponde a input, conforme especificado por format, formatProvider e styles.A time interval that corresponds to input, as specified by format, formatProvider, and styles.

Exceções

styles é um valor TimeSpanStyles inválido.styles is an invalid TimeSpanStyles value.

input tem um formato inválido.input has an invalid format.

input representa um número que é menor que MinValue ou maior que MaxValue.input represents a number that is less than MinValue or greater than MaxValue.

- ou --or- Pelo menos um dos componentes de dias, horas, minutos ou segundos em input está fora do intervalo válido.At least one of the days, hours, minutes, or seconds components in input is outside its valid range.

Exemplos

O exemplo a seguir usa ParseExact(String, String, IFormatProvider) o método para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias seqüências de formato e culturas.The following example uses the ParseExact(String, String, IFormatProvider) method to parse several string representations of time intervals using various format strings and cultures. Ele também usa o TimeSpanStyles.AssumeNegative valor para interpretar cada cadeia de caracteres como um intervalo de tempo negativo.It also uses the TimeSpanStyles.AssumeNegative value to interpret each string as a negative time interval. A saída do exemplo ilustra que o TimeSpanStyles.AssumeNegative estilo afeta o valor de retorno somente quando ele é usado com cadeias de caracteres de formato personalizado.The output from the example illustrates that the TimeSpanStyles.AssumeNegative style affects the return value only when it is used with custom format strings.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      string intervalString, format;
      TimeSpan interval;
      CultureInfo culture = null;
      
      // Parse hour:minute value with custom format specifier.
      intervalString = "17:14";
      format = "h\\:mm";
      culture = CultureInfo.CurrentCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      }      
      
      // Parse hour:minute:second value with "g" specifier.
      intervalString = "17:14:48";
      format = "g";
      culture = CultureInfo.InvariantCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse hours:minute.second value with custom format specifier.     
      intervalString = "17:14:48.153";
      format = @"h\:mm\:ss\.fff";
      culture = null;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 

      // Parse days:hours:minute.second value with "G" specifier 
      // and current (en-US) culture.     
      intervalString = "3:17:14:48.153";
      format = "G";
      culture = CultureInfo.CurrentCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
            
      // Parse days:hours:minute.second value with a custom format specifier.     
      intervalString = "3:17:14:48.153";
      format = @"d\:hh\:mm\:ss\.fff";
      culture = null;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse days:hours:minute.second value with "G" specifier 
      // and fr-FR culture.     
      intervalString = "3:17:14:48,153";
      format = "G";
      culture = new CultureInfo("fr-FR");
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 

      // Parse a single number using the "c" standard format string. 
      intervalString = "12";
      format = "c";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        null, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse a single number using the "%h" custom format string. 
      format = "%h";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        null, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse a single number using the "%s" custom format string. 
      format = "%s";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        null, TimeSpanStyles.AssumeNegative);
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
   }
}
// The example displays the following output:
//    '17:14' (h\:mm) --> -17:14:00
//    '17:14:48' (g) --> 17:14:48
//    '17:14:48.153' (h\:mm\:ss\.fff) --> -17:14:48.1530000
//    '3:17:14:48.153' (G) --> 3.17:14:48.1530000
//    '3:17:14:48.153' (d\:hh\:mm\:ss\.fff) --> -3.17:14:48.1530000
//    '3:17:14:48,153' (G) --> 3.17:14:48.1530000
//    '12' (c) --> 12.00:00:00
//    '12' (%h) --> -12:00:00
//    '12' (%s) --> -00:00:12
Imports System.Globalization

Module Example
   Public Sub Main()
      Dim intervalString, format As String
      Dim interval As TimeSpan
      Dim culture As CultureInfo = Nothing
      
      ' Parse hour:minute value with custom format specifier.
      intervalString = "17:14"
      format = "h\:mm"
      culture = CultureInfo.CurrentCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try      
      
      ' Parse hour:minute:second value with "g" specifier.
      intervalString = "17:14:48"
      format = "g"
      culture = CultureInfo.InvariantCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse hours:minute.second value with custom format specifier.     
      intervalString = "17:14:48.153"
      format = "h\:mm\:ss\.fff"
      culture = Nothing
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 

      ' Parse days:hours:minute.second value with "G" specifier 
      ' and current (en-US) culture.     
      intervalString = "3:17:14:48.153"
      format = "G"
      culture = CultureInfo.CurrentCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
            
      ' Parse days:hours:minute.second value with a custom format specifier.     
      intervalString = "3:17:14:48.153"
      format = "d\:hh\:mm\:ss\.fff"
      culture = Nothing
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse days:hours:minute.second value with "G" specifier 
      ' and fr-FR culture.     
      intervalString = "3:17:14:48,153"
      format = "G"
      culture = New CultureInfo("fr-FR")
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        culture, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 

      ' Parse a single number using the "c" standard format string. 
      intervalString = "12"
      format = "c"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        Nothing, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse a single number using the "%h" custom format string. 
      format = "%h"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        Nothing, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse a single number using the "%s" custom format string. 
      format = "%s"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, 
                                        Nothing, TimeSpanStyles.AssumeNegative)
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
   End Sub
End Module
' The example displays the following output:
'    '17:14' (h\:mm) --> -17:14:00
'    '17:14:48' (g) --> 17:14:48
'    '17:14:48.153' (h\:mm\:ss\.fff) --> -17:14:48.1530000
'    '3:17:14:48.153' (G) --> 3.17:14:48.1530000
'    '3:17:14:48.153' (d\:hh\:mm\:ss\.fff) --> -3.17:14:48.1530000
'    '3:17:14:48,153' (G) --> 3.17:14:48.1530000
'    '12' (c) --> 12.00:00:00
'    '12' (%h) --> -12:00:00
'    '12' (%s) --> -00:00:12

Comentários

O ParseExact método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido format pelo parâmetro, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados.The ParseExact method parses the string representation of a time interval, which must be in the format defined by the format parameter, except that leading and trailing white-space characters are ignored. Como input o deve estar em conformidade com format o formato de exatamente, você sempre deve usar a manipulação de exceção ao converter uma entrada de cadeia de caracteres pelo usuário em um intervalo de tempo.Because input must conform to the format of format exactly, you should always use exception handling when converting a string input by the user to a time interval. Se você preferir não usar a manipulação de exceção, você pode chamar TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) o método em vez disso.If you prefer not to use exception handling, you can call the TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) method instead.

O parâmetro format é uma cadeia de caracteres que contém um único especificador de formato padrão ou um ou mais especificadores de formato que definem o formato exigido de input.The format parameter is a string that contains either a single standard format specifier, or one or more custom format specifiers that define the required format of input. Para obter mais informações sobre cadeias de caracteres de formato válidas, consulte cadeias de caracteres de formato TimeSpan padrão e cadeias de caracteres de formatoFor more information about valid format strings, see Standard TimeSpan Format Strings and Custom TimeSpan Format Strings.

Importante

O ParseExact método usa as convenções da cultura especificada formatProvider pelo parâmetro somente se format for uma cadeia de caracteres TimeSpan de formato padrão cujo valor é "g" ou "g".The ParseExact method uses the conventions of the culture specified by the formatProvider parameter only if format is a standard TimeSpan format string whose value is either "g" or "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável.The "c", "t", and "T" standard format strings use the formatting conventions of the invariant culture. As cadeias de caracteres de formato personalizado definem o formato preciso da cadeia de caracteres de entrada e usam caracteres literais para separar os componentes de um intervalo de tempo.Custom format strings define the precise format of the input string and use literal characters to separate the components of a time interval.

O parâmetro formatProvider é uma implementação de IFormatProvider que fornece informações específicas de cultura sobre o formato da cadeia de caracteres retornado caso format seja uma cadeia de caracteres de formato padrão.The formatProvider parameter is an IFormatProvider implementation that provides culture-specific information about the format of the returned string if format is a standard format string. O parâmetro formatProvider pode ser um dos seguintes:The formatProvider parameter can be any of the following:

Caso formatProvider seja null, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.If formatProvider is null, the DateTimeFormatInfo object that is associated with the current culture is used.

O styles parâmetro afeta a interpretação de cadeias de caracteres que são analisadas usando cadeias de caracteres de formato personalizado.The styles parameter affects the interpretation of strings that are parsed using custom format strings. Ele determina se input só é interpretado como um intervalo de tempo negativo caso um sinal negativo esteja presente (TimeSpanStyles.None), ou se é sempre interpretado como um intervalo de tempo negativo (TimeSpanStyles.AssumeNegative).It determines whether input is interpreted as a negative time interval only if a negative sign is present (TimeSpanStyles.None), or whether it is always interpreted as a negative time interval (TimeSpanStyles.AssumeNegative). Se TimeSpanStyles.AssumeNegative não for usado, format deve incluir um símbolo de sinal negativo literal (como "\-") para analisar com êxito um intervalo de tempo negativo.If TimeSpanStyles.AssumeNegative is not used, format must include a literal negative sign symbol (such as "\-") to successfully parse a negative time interval.

Veja também

ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles)

public static TimeSpan ParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles = System.Globalization.TimeSpanStyles.None);
static member ParseExact : ReadOnlySpan<char> * string[] * IFormatProvider * System.Globalization.TimeSpanStyles -> TimeSpan
Public Shared Function ParseExact (input As ReadOnlySpan(Of Char), formats As String(), formatProvider As IFormatProvider, Optional styles As TimeSpanStyles = System.Globalization.TimeSpanStyles.None) As TimeSpan

Parâmetros

formats
String[]

Retornos

ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles) ParseExact(String, String[], IFormatProvider, TimeSpanStyles)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, as informações de formato específicas de cultura e os estilos.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified formats, culture-specific format information, and styles. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.The format of the string representation must match one of the specified formats exactly.

public:
 static TimeSpan ParseExact(System::String ^ input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles);
public static TimeSpan ParseExact (string input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles);
static member ParseExact : string * string[] * IFormatProvider * System.Globalization.TimeSpanStyles -> TimeSpan
Public Shared Function ParseExact (input As String, formats As String(), formatProvider As IFormatProvider, styles As TimeSpanStyles) As TimeSpan

Parâmetros

input
String String String String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.A string that specifies the time interval to convert.

formats
String[]

Uma matriz de cadeias de caracteres de formato personalizado ou padrão que define o formato de input exigido.A array of standard or custom format strings that define the required format of input.

formatProvider
IFormatProvider IFormatProvider IFormatProvider IFormatProvider

Um objeto que fornece informações de formatação específicas de cultura.An object that provides culture-specific formatting information.

styles
TimeSpanStyles TimeSpanStyles TimeSpanStyles TimeSpanStyles

Uma combinação bit a bit de valores de enumeração que define os elementos de estilo que podem estar presentes na entrada.A bitwise combination of enumeration values that defines the style elements that may be present in input.

Retornos

Um intervalo de tempo que corresponde a input, conforme especificado por formats, formatProvider e styles.A time interval that corresponds to input, as specified by formats, formatProvider, and styles.

Exceções

styles é um valor TimeSpanStyles inválido.styles is an invalid TimeSpanStyles value.

input tem um formato inválido.input has an invalid format.

input representa um número que é menor que MinValue ou maior que MaxValue.input represents a number that is less than MinValue or greater than MaxValue.

- ou --or- Pelo menos um dos componentes de dias, horas, minutos ou segundos em input está fora do intervalo válido.At least one of the days, hours, minutes, or seconds components in input is outside its valid range.

Exemplos

O exemplo a seguir chama ParseExact(String, String[], IFormatProvider, TimeSpanStyles) o método para converter cada elemento de uma matriz de cadeia TimeSpan de caracteres em um valor.The following example calls the ParseExact(String, String[], IFormatProvider, TimeSpanStyles) method to convert each element of a string array to a TimeSpan value. As cadeias de caracteres podem representar um intervalo de tempo no formato curto geral ou no formato longo geral.The strings can represent a time interval in either the general short format or the general long format.

Além disso, o exemplo altera a maneira como os métodos de análise do intervalo de tempo interpretam um dígito único.In addition, the example changes the way in which the time interval parsing methods interpret a single digit. Normalmente, um dígito único é interpretado como o número de dias em um intervalo de tempo.Ordinarily, a single digit is interpreted as the number of days in a time interval. Em vez disso, a cadeia de caracteres de formato personalizado %h é usada para interpretar um único dígito como o número de horas.Instead, the %h custom format string is used to interpret a single digit as the number of hours. Para que essa alteração seja efetiva, a cadeia de caracteres de formato personalizado %h deve preceder as outras cadeias de caracteres de formato na matriz formats.For this change to be effective, note that the %h custom format string must precede the other format strings in the formats array. Observe também a partir da saída que TimeSpanStyles.AssumeNegative o sinalizador especificado na chamada de método é usado somente ao analisar uma cadeia de caracteres com este especificador de formato.Also note from the output that the TimeSpanStyles.AssumeNegative flag specified in the method call is used only when parsing a string with this format specifier.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      string[] inputs = { "3", "16:42", "1:6:52:35.0625", 
                          "1:6:52:35,0625" }; 
      string[] formats = { "%h", "g", "G" };
      TimeSpan interval;
      CultureInfo culture = new CultureInfo("de-DE");
      
      // Parse each string in inputs using formats and the de-DE culture.
      foreach (string input in inputs) {
         try {
            interval = TimeSpan.ParseExact(input, formats, culture,
                                           TimeSpanStyles.AssumeNegative);
            Console.WriteLine("{0} --> {1:c}", input, interval);
         }
         catch (FormatException) {
            Console.WriteLine("{0} --> Bad Format", input);
         }      
         catch (OverflowException) {
            Console.WriteLine("{0} --> Overflow", input);   
         }            
      }
   }
}
// The example displays the following output:
//       3 --> -03:00:00
//       16:42 --> 16:42:00
//       1:6:52:35.0625 --> Bad Format
//       1:6:52:35,0625 --> 1.06:52:35.0625000
Imports System.Globalization

Module Example
   Public Sub Main()
      Dim inputs() As String = { "3", "16:42", "1:6:52:35.0625", 
                                 "1:6:52:35,0625" } 
      Dim formats() As String = { "%h", "g", "G" }
      Dim interval As TimeSpan
      Dim culture As New CultureInfo("de-DE")
      
      ' Parse each string in inputs using formats and the de-DE culture.
      For Each input As String In inputs
         Try
            interval = TimeSpan.ParseExact(input, formats, culture, 
                                           TimeSpanStyles.AssumeNegative)
            Console.WriteLine("{0} --> {1:c}", input, interval)   
         Catch e As FormatException
            Console.WriteLine("{0} --> Bad Format", input)   
         Catch e As OverflowException
            Console.WriteLine("{0} --> Overflow", input)   
         End Try            
      Next
   End Sub
End Module
' The example displays the following output:
'       3 --> -03:00:00
'       16:42 --> 16:42:00
'       1:6:52:35.0625 --> Bad Format
'       1:6:52:35,0625 --> 1.06:52:35.0625000

Comentários

O ParseExact(String, String[], IFormatProvider, TimeSpanStyles) método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar em um dos formatos definidos formats pelo parâmetro, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados.The ParseExact(String, String[], IFormatProvider, TimeSpanStyles) method parses the string representation of a time interval, which must be in one of the formats defined by the formats parameter, except that leading and trailing white-space characters are ignored. Como input o deve estar exatamente em conformidade com um dos formatos formatsespecificados em, você sempre deve usar a manipulação de exceção ao converter uma entrada de cadeia de caracteres pelo usuário em um intervalo de tempo.Because input must exactly conform to one of the formats specified in formats, you should always use exception handling when converting a string input by the user to a time interval. Se você preferir não usar a manipulação de exceção, você pode chamar TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) o método em vez disso.If you prefer not to use exception handling, you can call the TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) method instead.

O parâmetro formats é uma matriz de cadeias de caracteres cujos elementos consistem em um único especificador de formato padrão ou um ou mais especificadores de formato personalizado que definem o formato exigido de input.The formats parameter is a string array whose elements consist of either a single standard format specifier, or one or more custom format specifiers that define the required format of input. Para obter mais informações sobre cadeias de caracteres de formato válidas, consulte cadeias de caracteres de formato TimeSpan padrão e cadeias de caracteres de formatoFor more information about valid format strings, see Standard TimeSpan Format Strings and Custom TimeSpan Format Strings. input deve corresponder exatamente a um membro de formats para que a operação de análise seja bem-sucedida.input must correspond exactly to a member of formats for the parse operation to succeed. A operação de análise tenta comparar input com cada elemento em formats começando pelo primeiro elemento na matriz.The parse operation attempts to match input to each element in formats starting with the first element in the array.

Importante

O ParseExact método usará as convenções da cultura especificada formatProvider pelo parâmetro somente se a cadeia de caracteres de formato usada input para análise for TimeSpan uma cadeia de caracteres de formato padrão cujo valor é "g" ou "g".The ParseExact method uses the conventions of the culture specified by the formatProvider parameter only if the format string used to parse input is a standard TimeSpan format string whose value is either "g" or "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável.The "c", "t", and "T" standard format strings use the formatting conventions of the invariant culture. As cadeias de caracteres de formato personalizado definem o formato preciso da cadeia de caracteres de entrada e usam caracteres literais para separar os componentes de um intervalo de tempo.Custom format strings define the precise format of the input string and use literal characters to separate the components of a time interval.

O parâmetro formatProvider é uma implementação de IFormatProvider que fornece informações específicas de cultura sobre o formato da cadeia de caracteres retornado caso a cadeia de caracteres do formato usada para analisar input seja uma cadeia de caracteres de formato padrão.The formatProvider parameter is an IFormatProvider implementation that provides culture-specific information about the format of the returned string if the format string used to parse input is a standard format string. O parâmetro formatProvider pode ser um dos seguintes:The formatProvider parameter can be any of the following:

Caso formatProvider seja null, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.If formatProvider is null, the DateTimeFormatInfo object that is associated with the current culture is used.

O styles parâmetro afeta a interpretação de cadeias de caracteres que são analisadas usando cadeias de caracteres de formato personalizado.The styles parameter affects the interpretation of strings that are parsed using custom format strings. Ele determina se input só é interpretado como um intervalo de tempo negativo caso um sinal negativo esteja presente (TimeSpanStyles.None), ou se é sempre interpretado como um intervalo de tempo negativo (TimeSpanStyles.AssumeNegative).It determines whether input is interpreted as a negative time interval only if a negative sign is present (TimeSpanStyles.None), or whether it is always interpreted as a negative time interval (TimeSpanStyles.AssumeNegative). Se TimeSpanStyles.AssumeNegative não for usado, format deve incluir um símbolo de sinal negativo literal (como "\-") para analisar com êxito um intervalo de tempo negativo.If TimeSpanStyles.AssumeNegative is not used, format must include a literal negative sign symbol (such as "\-") to successfully parse a negative time interval.

Veja também

ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider) ParseExact(String, String[], IFormatProvider)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando a matriz de cadeias de caracteres de formato especificada e as informações de formato específicas de cultura.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified array of format strings and culture-specific format information. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.The format of the string representation must match one of the specified formats exactly.

public:
 static TimeSpan ParseExact(System::String ^ input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider);
public static TimeSpan ParseExact (string input, string[] formats, IFormatProvider formatProvider);
static member ParseExact : string * string[] * IFormatProvider -> TimeSpan
Public Shared Function ParseExact (input As String, formats As String(), formatProvider As IFormatProvider) As TimeSpan

Parâmetros

input
String String String String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.A string that specifies the time interval to convert.

formats
String[]

Uma matriz de cadeias de caracteres de formato personalizado ou padrão que define o formato de input exigido.A array of standard or custom format strings that defines the required format of input.

formatProvider
IFormatProvider IFormatProvider IFormatProvider IFormatProvider

Um objeto que fornece informações de formatação específicas de cultura.An object that provides culture-specific formatting information.

Retornos

Um intervalo de tempo que corresponde a input, conforme especificado por formats e formatProvider.A time interval that corresponds to input, as specified by formats and formatProvider.

Exceções

input tem um formato inválido.input has an invalid format.

input representa um número que é menor que MinValue ou maior que MaxValue.input represents a number that is less than MinValue or greater than MaxValue.

- ou --or- Pelo menos um dos componentes de dias, horas, minutos ou segundos em input está fora do intervalo válido.At least one of the days, hours, minutes, or seconds components in input is outside its valid range.

Exemplos

O exemplo a seguir chama ParseExact(String, String[], IFormatProvider) o método para converter cada elemento de uma matriz de cadeia TimeSpan de caracteres em um valor.The following example calls the ParseExact(String, String[], IFormatProvider) method to convert each element of a string array to a TimeSpan value. O exemplo interpreta as cadeias de caracteres usando as convenções de formatação da cultura francesa-França ("fr-FR").The example interprets the strings using the formatting conventions of the French - France ("fr-FR") culture. As cadeias de caracteres podem representar um intervalo de tempo no formato curto geral ou no formato longo geral.The strings can represent a time interval in either the general short format or the general long format.

Além disso, o exemplo altera a maneira como os métodos de análise do intervalo de tempo interpretam um dígito único.In addition, the example changes the way in which the time interval parsing methods interpret a single digit. Normalmente, um dígito único é interpretado como o número de dias em um intervalo de tempo.Ordinarily, a single digit is interpreted as the number of days in a time interval. Em vez disso, a cadeia de caracteres de formato personalizado %h é usada para interpretar um único dígito como o número de horas.Instead, the %h custom format string is used to interpret a single digit as the number of hours. Para que essa alteração seja efetiva, a cadeia de caracteres de formato personalizado %h deve preceder as outras cadeias de caracteres de formato na matriz formats.For this change to be effective, note that the %h custom format string must precede the other format strings in the formats array.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      string[] inputs = { "3", "16:42", "1:6:52:35.0625", 
                          "1:6:52:35,0625" }; 
      string[] formats = { "g", "G", "%h"};
      TimeSpan interval;
      CultureInfo culture = new CultureInfo("fr-FR");
      
      // Parse each string in inputs using formats and the fr-FR culture.
      foreach (string input in inputs) {
         try {
            interval = TimeSpan.ParseExact(input, formats, culture);
            Console.WriteLine("{0} --> {1:c}", input, interval);
         }
         catch (FormatException) {
            Console.WriteLine("{0} --> Bad Format", input);
         }      
         catch (OverflowException) {
            Console.WriteLine("{0} --> Overflow", input);   
         }            
      }
   }
}
// The example displays the following output:
//       3 --> 03:00:00
//       16:42 --> 16:42:00
//       1:6:52:35.0625 --> Bad Format
//       1:6:52:35,0625 --> 1.06:52:35.0625000
Imports System.Globalization

Module Example
   Public Sub Main()
      Dim inputs() As String = { "3", "16:42", "1:6:52:35.0625", 
                                 "1:6:52:35,0625" } 
      Dim formats() As String = { "%h", "g", "G" }
      Dim interval As TimeSpan
      Dim culture As New CultureInfo("fr-FR")
      
      ' Parse each string in inputs using formats and the fr-FR culture.
      For Each input As String In inputs
         Try
            interval = TimeSpan.ParseExact(input, formats, culture)
            Console.WriteLine("{0} --> {1:c}", input, interval)   
         Catch e As FormatException
            Console.WriteLine("{0} --> Bad Format", input)   
         Catch e As OverflowException
            Console.WriteLine("{0} --> Overflow", input)   
         End Try            
      Next
   End Sub
End Module
' The example displays the following output:
'       3 --> 3.00:00:00
'       16:42 --> 16:42:00
'       1:6:52:35.0625 --> Bad Format
'       1:6:52:35,0625 --> 1.06:52:35.0625000

Comentários

O ParseExact(String, String, IFormatProvider) método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar em um dos formatos definidos formats pelo parâmetro, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados.The ParseExact(String, String, IFormatProvider) method parses the string representation of a time interval, which must be in one of the formats defined by the formats parameter, except that leading and trailing white-space characters are ignored. Como input o deve estar exatamente em conformidade com um dos formatos formatsespecificados em, você sempre deve usar a manipulação de exceção ao converter uma entrada de cadeia de caracteres pelo usuário em um intervalo de tempo.Because input must exactly conform to one of the formats specified in formats, you should always use exception handling when converting a string input by the user to a time interval. Se você preferir não usar a manipulação de exceção, você pode chamar TryParseExact(String, String[], IFormatProvider, TimeSpan) o método em vez disso.If you prefer not to use exception handling, you can call the TryParseExact(String, String[], IFormatProvider, TimeSpan) method instead.

O parâmetro formats é uma matriz de cadeias de caracteres cujos elementos consistem em um único especificador de formato padrão ou um ou mais especificadores de formato personalizado que definem o formato exigido de input.The formats parameter is a string array whose elements consist of either a single standard format specifier, or one or more custom format specifiers that define the required format of input. Para obter mais informações sobre cadeias de caracteres de formato válidas, consulte cadeias de caracteres de formato TimeSpan padrão e cadeias de caracteres de formatoFor more information about valid format strings, see Standard TimeSpan Format Strings and Custom TimeSpan Format Strings. input deve corresponder exatamente a um membro de formats para que a operação de análise seja bem-sucedida.input must correspond exactly to a member of formats for the parse operation to succeed. A operação de análise tenta comparar input com cada elemento em formats começando pelo primeiro elemento na matriz.The parse operation attempts to match input to each element in formats starting with the first element in the array.

Importante

O ParseExact método usará as convenções da cultura especificada formatProvider pelo parâmetro somente se a cadeia de caracteres de formato usada input para análise for TimeSpan uma cadeia de caracteres de formato padrão cujo valor é "g" ou "g".The ParseExact method uses the conventions of the culture specified by the formatProvider parameter only if the format string used to parse input is a standard TimeSpan format string whose value is either "g" or "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável.The "c", "t", and "T" standard format strings use the formatting conventions of the invariant culture. As cadeias de caracteres de formato personalizado definem o formato preciso da cadeia de caracteres de entrada e usam caracteres literais para separar os componentes de um intervalo de tempo.Custom format strings define the precise format of the input string and use literal characters to separate the components of a time interval.

O parâmetro formatProvider é uma implementação de IFormatProvider que fornece informações específicas de cultura sobre o formato da cadeia de caracteres retornado caso a cadeia de caracteres do formato usada para analisar input seja uma cadeia de caracteres de formato padrão.The formatProvider parameter is an IFormatProvider implementation that provides culture-specific information about the format of the returned string if the format string used to parse input is a standard format string. O parâmetro formatProvider pode ser um dos seguintes:The formatProvider parameter can be any of the following:

Caso formatProvider seja null, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.If formatProvider is null, the DateTimeFormatInfo object that is associated with the current culture is used.

Veja também

ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider) ParseExact(String, String, IFormatProvider)

Converte a representação de cadeia de caracteres de um intervalo de hora em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura especificadas.Converts the string representation of a time interval to its TimeSpan equivalent by using the specified format and culture-specific format information. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.The format of the string representation must match the specified format exactly.

public:
 static TimeSpan ParseExact(System::String ^ input, System::String ^ format, IFormatProvider ^ formatProvider);
public static TimeSpan ParseExact (string input, string format, IFormatProvider formatProvider);
static member ParseExact : string * string * IFormatProvider -> TimeSpan
Public Shared Function ParseExact (input As String, format As String, formatProvider As IFormatProvider) As TimeSpan

Parâmetros

input
String String String String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.A string that specifies the time interval to convert.

format
String String String String

Uma cadeia de caracteres de formato padrão ou personalizada que define o formato obrigatório de input.A standard or custom format string that defines the required format of input.

formatProvider
IFormatProvider IFormatProvider IFormatProvider IFormatProvider

Um objeto que fornece informações de formatação específicas de cultura.An object that provides culture-specific formatting information.

Retornos

Um intervalo de tempo que corresponde a input, conforme especificado por format e formatProvider.A time interval that corresponds to input, as specified by format and formatProvider.

Exceções

input tem um formato inválido.input has an invalid format.

input representa um número que é menor que MinValue ou maior que MaxValue.input represents a number that is less than MinValue or greater than MaxValue.

- ou --or- Pelo menos um dos componentes de dias, horas, minutos ou segundos em input está fora do intervalo válido.At least one of the days, hours, minutes, or seconds components in input is outside its valid range.

Exemplos

O exemplo a seguir usa ParseExact(String, String, IFormatProvider) o método para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias seqüências de formato e culturas.The following example uses the ParseExact(String, String, IFormatProvider) method to parse several string representations of time intervals using various format strings and cultures.

using System;
using System.Globalization;

public class Example
{
   public static void Main()
   {
      string intervalString, format;
      TimeSpan interval;
      CultureInfo culture;
      
      // Parse hour:minute value with "g" specifier current culture.
      intervalString = "17:14";
      format = "g";
      culture = CultureInfo.CurrentCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", 
                           intervalString, format);
      }                     
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      }      
      
      // Parse hour:minute:second value with "G" specifier.
      intervalString = "17:14:48";
      format = "G";
      culture = CultureInfo.InvariantCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse hours:minute.second value with "G" specifier 
      // and current (en-US) culture.     
      intervalString = "17:14:48.153";
      format = "G";
      culture = CultureInfo.CurrentCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 

      // Parse days:hours:minute.second value with "G" specifier 
      // and current (en-US) culture.     
      intervalString = "3:17:14:48.153";
      format = "G";
      culture = CultureInfo.CurrentCulture;
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }   
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
            
      // Parse days:hours:minute.second value with "G" specifier 
      // and fr-FR culture.     
      intervalString = "3:17:14:48.153";
      format = "G";
      culture = new CultureInfo("fr-FR");
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse days:hours:minute.second value with "G" specifier 
      // and fr-FR culture.     
      intervalString = "3:17:14:48,153";
      format = "G";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, culture);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }   
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 

      // Parse a single number using the "c" standard format string. 
      intervalString = "12";
      format = "c";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, null);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse a single number using the "%h" custom format string. 
      format = "%h";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, null);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      } 
      
      // Parse a single number using the "%s" custom format string. 
      format = "%s";
      try {
         interval = TimeSpan.ParseExact(intervalString, format, null);
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      }
      catch (FormatException) {
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format);
      }
      catch (OverflowException) {
         Console.WriteLine("'{0}': Overflow", intervalString);
      }
   }
}
// The example displays the following output:
//       '17:14' --> 17:14:00
//       '17:14:48': Bad Format for 'G'
//       '17:14:48.153': Bad Format for 'G'
//       '3:17:14:48.153' --> 3.17:14:48.1530000
//       '3:17:14:48.153': Bad Format for 'G'
//       '3:17:14:48,153' --> 3.17:14:48.1530000
//       '12' --> 12.00:00:00
//       '12' --> 12:00:00
//       '12' --> 00:00:12
Imports System.Globalization

Module Example
   Public Sub Main()
      Dim intervalString, format As String
      Dim interval As TimeSpan
      Dim culture As CultureInfo
      
      ' Parse hour:minute value with "g" specifier current culture.
      intervalString = "17:14"
      format = "g"
      culture = CultureInfo.CurrentCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try      
      
      ' Parse hour:minute:second value with "G" specifier.
      intervalString = "17:14:48"
      format = "G"
      culture = CultureInfo.InvariantCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse hours:minute.second value with "G" specifier 
      ' and current (en-US) culture.     
      intervalString = "17:14:48.153"
      format = "G"
      culture = CultureInfo.CurrentCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 

      ' Parse days:hours:minute.second value with "G" specifier 
      ' and current (en-US) culture.     
      intervalString = "3:17:14:48.153"
      format = "G"
      culture = CultureInfo.CurrentCulture
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
            
      ' Parse days:hours:minute.second value with "G" specifier 
      ' and fr-FR culture.     
      intervalString = "3:17:14:48.153"
      format = "G"
      culture = New CultureInfo("fr-FR")
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse days:hours:minute.second value with "G" specifier 
      ' and fr-FR culture.     
      intervalString = "3:17:14:48,153"
      format = "G"
      culture = New CultureInfo("fr-FR")
      Try
         interval = TimeSpan.ParseExact(intervalString, format, culture)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 

      ' Parse a single number using the "c" standard format string. 
      intervalString = "12"
      format = "c"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, Nothing)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse a single number using the "%h" custom format string. 
      format = "%h"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, Nothing)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
      
      ' Parse a single number using the "%s" custom format string. 
      format = "%s"
      Try
         interval = TimeSpan.ParseExact(intervalString, format, Nothing)
         Console.WriteLine("'{0}' --> {1}", intervalString, interval)
      Catch e As FormatException
         Console.WriteLine("'{0}': Bad Format for '{1}'", intervalString, format)
      Catch e As OverflowException
         Console.WriteLine("'{0}': Overflow", intervalString)
      End Try 
   End Sub
End Module
' The example displays the following output:
'       '17:14' --> 17:14:00
'       '17:14:48': Bad Format for 'G'
'       '17:14:48.153': Bad Format for 'G'
'       '3:17:14:48.153' --> 3.17:14:48.1530000
'       '3:17:14:48.153': Bad Format for 'G'
'       '3:17:14:48,153' --> 3.17:14:48.1530000
'       '12' --> 12.00:00:00
'       '12' --> 12:00:00
'       '12' --> 00:00:12

Comentários

O ParseExact(String, String, IFormatProvider) método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido format pelo parâmetro, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados.The ParseExact(String, String, IFormatProvider) method parses the string representation of a time interval, which must be in the format defined by the format parameter, except that leading and trailing white-space characters are ignored. Como input o deve estar em conformidade com format o formato de exatamente, você sempre deve usar a manipulação de exceção ao converter uma entrada de cadeia de caracteres pelo usuário em um intervalo de tempo.Because input must conform to the format of format exactly, you should always use exception handling when converting a string input by the user to a time interval. Se você preferir não usar a manipulação de exceção, você pode chamar TryParseExact(String, String, IFormatProvider, TimeSpan) o método em vez disso.If you prefer not to use exception handling, you can call the TryParseExact(String, String, IFormatProvider, TimeSpan) method instead.

O parâmetro format é uma cadeia de caracteres que contém um único especificador de formato padrão ou um ou mais especificadores de formato que definem o formato exigido de input.The format parameter is a string that contains either a single standard format specifier, or one or more custom format specifiers that define the required format of input. Para obter mais informações sobre cadeias de caracteres de formato válidas, consulte cadeias de caracteres de formato TimeSpan padrão e cadeias de caracteres de formatoFor more information about valid format strings, see Standard TimeSpan Format Strings and Custom TimeSpan Format Strings.

Importante

O ParseExact método usa as convenções da cultura especificada formatProvider pelo parâmetro somente se format for uma cadeia de caracteres TimeSpan de formato padrão cujo valor é "g" ou "g".The ParseExact method uses the conventions of the culture specified by the formatProvider parameter only if format is a standard TimeSpan format string whose value is either "g" or "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável.The "c", "t", and "T" standard format strings use the formatting conventions of the invariant culture. As cadeias de caracteres de formato personalizado definem o formato preciso da cadeia de caracteres de entrada e usam caracteres literais para separar os componentes de um intervalo de tempo.Custom format strings define the precise format of the input string and use literal characters to separate the components of a time interval.

O parâmetro formatProvider é uma implementação de IFormatProvider que fornece informações específicas de cultura sobre o formato da cadeia de caracteres retornado caso format seja uma cadeia de caracteres de formato padrão.The formatProvider parameter is an IFormatProvider implementation that provides culture-specific information about the format of the returned string if format is a standard format string. O parâmetro formatProvider pode ser um dos seguintes:The formatProvider parameter can be any of the following:

Caso formatProvider seja null, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.If formatProvider is null, the DateTimeFormatInfo object that is associated with the current culture is used.

Veja também

ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles) ParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles)

public static TimeSpan ParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles = System.Globalization.TimeSpanStyles.None);
static member ParseExact : ReadOnlySpan<char> * ReadOnlySpan<char> * IFormatProvider * System.Globalization.TimeSpanStyles -> TimeSpan
Public Shared Function ParseExact (input As ReadOnlySpan(Of Char), format As ReadOnlySpan(Of Char), formatProvider As IFormatProvider, Optional styles As TimeSpanStyles = System.Globalization.TimeSpanStyles.None) As TimeSpan

Parâmetros

format
ReadOnlySpan<Char>

Retornos

Aplica-se a