Ler em inglês

Compartilhar via


TimeSpan.TryParseExact Método

Definição

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente e retorna um valor que indica se a conversão foi bem-sucedida. O formato da representação de cadeia de caracteres deve corresponder exatamente a um formato especificado.

Sobrecargas

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

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, informações e estilos de formato específicos da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado, informações e estilos de formato específicos da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

TryParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles, TimeSpan)

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado, informações de formato e estilos específicos da cultura e retorna um valor que indica se a conversão foi bem-sucedida. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

TryParseExact(String, String[], IFormatProvider, TimeSpan)

Converte a representação de cadeia de caracteres especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan)

Converte a representação de cadeia de caracteres especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, informações e estilos de formato específicos à cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

TryParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpan)

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

TryParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpan)

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

TryParseExact(String, String, IFormatProvider, TimeSpan)

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

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

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, informações e estilos de formato específicos da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

C#
public static bool TryParseExact (ReadOnlySpan<char> input, string?[]? formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);

Parâmetros

input
ReadOnlySpan<Char>

Um intervalo que contém os caracteres que representam um intervalo de tempo a ser convertido.

formats
String[]

Uma matriz de cadeias de caracteres de formato padrão ou personalizado que definem os formatos aceitáveis de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

styles
TimeSpanStyles

Um ou mais valores de enumeração que indicam o estilo de input.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado, informações e estilos de formato específicos da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

C#
public static bool TryParseExact (string input, string format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string? format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);

Parâmetros

input
String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.

format
String

Uma cadeia de caracteres de formato padrão ou personalizado que define o formato necessário de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

styles
TimeSpanStyles

Um ou mais valores de enumeração que indicam o estilo de input.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Exemplos

O exemplo a seguir usa o método ParseExact(String, String, IFormatProvider) para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias cadeias de caracteres e culturas de formato. Ele também usa o valor TimeSpanStyles.AssumeNegative para interpretar cada cadeia de caracteres como um intervalo de tempo negativo. A saída do exemplo ilustra que o estilo TimeSpanStyles.AssumeNegative afeta o valor retornado somente quando ele é usado com cadeias de caracteres de formato personalizado.

C#
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;
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
      
      // Parse hour:minute:second value with "g" specifier.
      intervalString = "17:14:48";
      format = "g";
      culture = CultureInfo.InvariantCulture;
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
      
      // Parse hours:minute.second value with custom format specifier.     
      intervalString = "17:14:48.153";
      format = @"h\:mm\:ss\.fff";
      culture = null;
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);   

      // 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;
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);   
            
      // 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;
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
      
      // 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");
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 culture, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);

      // Parse a single number using the "c" standard format string. 
      intervalString = "12";
      format = "c";
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 null, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
      
      // Parse a single number using the "%h" custom format string. 
      format = "%h";
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 null, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
      
      // Parse a single number using the "%s" custom format string. 
      format = "%s";
      if (TimeSpan.TryParseExact(intervalString, format, 
                                 null, TimeSpanStyles.AssumeNegative, out interval))
         Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval);
      else   
         Console.WriteLine("Unable to parse '{0}' using format {1}",
                           intervalString, format);
   }
}
// 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 método TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido pelo parâmetro format, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao método ParseExact(String, String, IFormatProvider, TimeSpanStyles), exceto pelo fato de não gerar uma exceção se a conversão falhar.

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 personalizado que definem o formato necessário de 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 formato TimeSpan personalizadas.

O parâmetro formatProvider é uma implementação IFormatProvider que fornece informações específicas da cultura sobre o formato da cadeia de caracteres retornada se format for uma cadeia de caracteres de formato padrão. O parâmetro formatProvider pode ser qualquer um dos seguintes:

Se formatProvider for null, o objeto DateTimeFormatInfo associado à cultura atual será usado.

O parâmetro styles afeta a interpretação de cadeias de caracteres analisadas usando cadeias de caracteres de formato personalizado. Ele determina se input é interpretado como um intervalo de tempo negativo somente se um sinal negativo estiver presente (TimeSpanStyles.None) ou se ele é sempre interpretado como um intervalo de tempo negativo (TimeSpanStyles.AssumeNegative). Se TimeSpanStyles.AssumeNegative não for usado, format deverá incluir um símbolo de sinal negativo literal (como "\-") para analisar com êxito um intervalo de tempo negativo.

Confira também

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

TryParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado, informações de formato e estilos específicos da cultura e retorna um valor que indica se a conversão foi bem-sucedida. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

C#
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);

Parâmetros

input
ReadOnlySpan<Char>

Um intervalo que contém os caracteres que representam um intervalo de tempo a ser convertido.

format
ReadOnlySpan<Char>

Um intervalo que contém as charactes que representam uma cadeia de caracteres de formato padrão ou personalizada que define o formato aceitável de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

styles
TimeSpanStyles

Um ou mais valores de enumeração que indicam o estilo de input.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

TryParseExact(String, String[], IFormatProvider, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de cadeia de caracteres especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

C#
public static bool TryParseExact (string input, string[] formats, IFormatProvider formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string?[]? formats, IFormatProvider? formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string[] formats, IFormatProvider? formatProvider, out TimeSpan result);

Parâmetros

input
String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.

formats
String[]

Uma matriz de cadeias de caracteres de formato padrão ou personalizado que definem os formatos aceitáveis de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Exemplos

O exemplo a seguir chama o método TryParseExact(String, String[], IFormatProvider, TimeSpan) para converter cada elemento de uma matriz de cadeia de caracteres em um valor TimeSpan. O exemplo interpreta as cadeias de caracteres usando as convenções de formatação da cultura francesa - França ("fr-FR"). As cadeias de caracteres podem representar um intervalo de tempo no formato curto geral ou no formato longo geral.

Além disso, o exemplo altera a maneira como os métodos de análise de intervalo de tempo interpretam um único dígito. Normalmente, um único dígito é interpretado como o número de dias em um intervalo de tempo. Em vez disso, a cadeia de caracteres de formato personalizado %h é usada para interpretar um único dígito como o número de horas. Para que essa alteração seja eficaz, observe que a cadeia de caracteres de formato personalizado %h deve preceder as outras cadeias de caracteres de formato na matriz formats.

C#
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) {
         if(TimeSpan.TryParseExact(input, formats, culture, out interval))
            Console.WriteLine("{0} --> {1:c}", input, interval);
         else
            Console.WriteLine("Unable to parse {0}", input);   
      }
   }
}
// The example displays the following output:
//       3 --> 03:00:00
//       16:42 --> 16:42:00
//       Unable to parse 1:6:52:35.0625
//       1:6:52:35,0625 --> 1.06:52:35.0625000

Comentários

O método TryParseExact(String, String[], IFormatProvider, TimeSpan) analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido por uma das cadeias de caracteres de formato especificadas pelo parâmetro formats, exceto que caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao método ParseExact(String, String[], IFormatProvider), exceto pelo fato de não gerar uma exceção se a conversão falhar.

O parâmetro formats é uma matriz de cadeia 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 necessário de 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 formato TimeSpan personalizadas. input deve corresponder exatamente a um membro do formats para que a operação de análise seja bem-sucedida. A operação de análise tenta corresponder input a cada elemento em formats começando com o primeiro elemento na matriz.

Importante

O método TryParseExact usa as convenções da cultura especificadas pelo parâmetro formatProvider somente se a cadeia de caracteres de formato usada para analisar input for uma cadeia de caracteres de formato de TimeSpan padrão cujo valor seja "g" ou "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável. 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.

O parâmetro formatProvider é uma implementação IFormatProvider que fornece informações específicas da cultura sobre o formato da cadeia de caracteres retornada se a cadeia de caracteres de formato usada para analisar input for uma cadeia de caracteres de formato padrão. O parâmetro formatProvider pode ser qualquer um dos seguintes:

Se formatProvider for null, o objeto DateTimeFormatInfo associado à cultura atual será usado.

Confira também

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de cadeia de caracteres especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados, informações e estilos de formato específicos à cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

C#
public static bool TryParseExact (string input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string?[]? formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string[] formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);

Parâmetros

input
String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.

formats
String[]

Uma matriz de cadeias de caracteres de formato padrão ou personalizado que definem os formatos aceitáveis de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

styles
TimeSpanStyles

Um ou mais valores de enumeração que indicam o estilo de input.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Exemplos

O exemplo a seguir chama o método TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) para converter cada elemento de uma matriz de cadeia de caracteres em um valor TimeSpan. As cadeias de caracteres podem representar um intervalo de tempo no formato curto geral ou no formato longo geral.

Além disso, o exemplo altera a maneira como os métodos de análise de intervalo de tempo interpretam um único dígito. Normalmente, um único dígito é interpretado como o número de dias em um intervalo de tempo. Em vez disso, a cadeia de caracteres de formato personalizado %h é usada para interpretar um único dígito como o número de horas. Para que essa alteração seja eficaz, observe que a cadeia de caracteres de formato personalizado %h deve preceder as outras cadeias de caracteres de formato na matriz formats. Observe também na saída que o sinalizador de TimeSpanStyles.AssumeNegative especificado na chamada de método é usado somente ao analisar uma cadeia de caracteres com esse especificador de formato.

C#
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("fr-FR");
      
      // Parse each string in inputs using formats and the fr-FR culture.
      foreach (string input in inputs) {
         if(TimeSpan.TryParseExact(input, formats, culture, 
                                   TimeSpanStyles.AssumeNegative, out interval))
            Console.WriteLine("{0} --> {1:c}", input, interval);
         else
            Console.WriteLine("Unable to parse {0}", input);   
      }
   }
}
// The example displays the following output:
//       3 --> -03:00:00
//       16:42 --> 16:42:00
//       Unable to parse 1:6:52:35.0625
//       1:6:52:35,0625 --> 1.06:52:35.0625000

Comentários

O método TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido por uma das cadeias de caracteres de formato especificadas pelo parâmetro formats, exceto que caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao método ParseExact(String, String[], IFormatProvider, TimeSpanStyles), exceto pelo fato de não gerar uma exceção se a conversão falhar.

O parâmetro formats é uma matriz de cadeia 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 necessário de 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 formato TimeSpan personalizadas. input deve corresponder exatamente a um membro do formats para que a operação de análise seja bem-sucedida. A operação de análise tenta corresponder input a cada elemento em formats começando com o primeiro elemento na matriz.

Importante

O método ParseExact usa as convenções da cultura especificadas pelo parâmetro formatProvider somente se a cadeia de caracteres de formato usada para analisar input for uma cadeia de caracteres de formato de TimeSpan padrão cujo valor seja "g" ou "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável. 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.

O parâmetro formatProvider é uma implementação IFormatProvider que fornece informações específicas da cultura sobre o formato da cadeia de caracteres retornada se a cadeia de caracteres de formato usada para analisar input for uma cadeia de caracteres de formato padrão. O parâmetro formatProvider pode ser qualquer um dos seguintes:

Se formatProvider for null, o objeto DateTimeFormatInfo associado à cultura atual será usado.

O parâmetro styles afeta a interpretação de cadeias de caracteres que são analisadas usando cadeias de caracteres de formato personalizado. Ele determina se input é interpretado como um intervalo de tempo negativo somente se um sinal negativo estiver presente (TimeSpanStyles.None) ou se ele é sempre interpretado como um intervalo de tempo negativo (TimeSpanStyles.AssumeNegative). Se TimeSpanStyles.AssumeNegative não for usado, format deverá incluir um símbolo de sinal negativo literal (como "\-") para analisar com êxito um intervalo de tempo negativo.

Confira também

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

TryParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando os formatos especificados e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.

C#
public static bool TryParseExact (ReadOnlySpan<char> input, string?[]? formats, IFormatProvider? formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider? formatProvider, out TimeSpan result);

Parâmetros

input
ReadOnlySpan<Char>

Um intervalo que contém os caracteres que representam um intervalo de tempo a ser convertido.

formats
String[]

Uma matriz de cadeias de caracteres de formato padrão ou personalizado que definem os formatos aceitáveis de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

TryParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de intervalo especificada de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

C#
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider? formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider formatProvider, out TimeSpan result);

Parâmetros

input
ReadOnlySpan<Char>

Um intervalo que contém os caracteres que representam um intervalo de tempo a ser convertido.

format
ReadOnlySpan<Char>

Um intervalo que contém os caracteres que representam uma cadeia de caracteres de formato padrão ou personalizado que define o formato aceitável de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Standard 2.1

TryParseExact(String, String, IFormatProvider, TimeSpan)

Origem:
TimeSpan.cs
Origem:
TimeSpan.cs
Origem:
TimeSpan.cs

Converte a representação de cadeia de caracteres de um intervalo de tempo em seu TimeSpan equivalente usando o formato especificado e as informações de formato específicas da cultura. O formato da representação de cadeia de caracteres deve corresponder exatamente ao formato especificado.

C#
public static bool TryParseExact (string input, string format, IFormatProvider formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string? format, IFormatProvider? formatProvider, out TimeSpan result);
C#
public static bool TryParseExact (string? input, string format, IFormatProvider? formatProvider, out TimeSpan result);

Parâmetros

input
String

Uma cadeia de caracteres que especifica o intervalo de tempo a ser convertido.

format
String

Uma cadeia de caracteres de formato padrão ou personalizado que define o formato necessário de input.

formatProvider
IFormatProvider

Um objeto que fornece informações de formatação específicas da cultura.

result
TimeSpan

Quando esse método é retornado, contém um objeto que representa o intervalo de tempo especificado por inputou Zero se a conversão falhou. Esse parâmetro é passado sem inicialização.

Retornos

true se input foi convertido com êxito; caso contrário, false.

Exemplos

O exemplo a seguir usa o método TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias cadeias de caracteres e culturas de formato.

C#
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;
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
      
      // Parse hour:minute:second value with "G" specifier.
      intervalString = "17:14:48";
      format = "G";
      culture = CultureInfo.InvariantCulture;
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
      
      // Parse hours:minute.second value with "G" specifier 
      // and current (en-US) culture.     
      intervalString = "17:14:48.153";
      format = "G";
      culture = CultureInfo.CurrentCulture;
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", 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;
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", 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");
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
      
      // Parse days:hours:minute.second value with "G" specifier 
      // and fr-FR culture.     
      intervalString = "3:17:14:48,153";
      format = "G";
      if (TimeSpan.TryParseExact(intervalString, format, culture, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);

      // Parse a single number using the "c" standard format string. 
      intervalString = "12";
      format = "c";
      if (TimeSpan.TryParseExact(intervalString, format, null, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
      
      // Parse a single number using the "%h" custom format string. 
      format = "%h";
      if (TimeSpan.TryParseExact(intervalString, format, null, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
      
      // Parse a single number using the "%s" custom format string. 
      format = "%s";
      if (TimeSpan.TryParseExact(intervalString, format, null, out interval))
         Console.WriteLine("'{0}' --> {1}", intervalString, interval);
      else
         Console.WriteLine("Unable to parse {0}", intervalString);
   }
}
// The example displays the following output:
//       '17:14' --> 17:14:00
//       Unable to parse 17:14:48
//       Unable to parse 17:14:48.153
//       '3:17:14:48.153' --> 3.17:14:48.1530000
//       Unable to parse 3:17:14:48.153
//       '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 método TryParseExact(String, String, IFormatProvider, TimeSpan) analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido pelo parâmetro format, exceto que os caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao método ParseExact(String, String, IFormatProvider), exceto pelo fato de não gerar uma exceção se a conversão falhar.

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 personalizado que definem o formato necessário de 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 formato TimeSpan personalizadas.

Importante

O método TryParseExact(String, String, IFormatProvider, TimeSpan) usa as convenções da cultura especificadas pelo parâmetro formatProvider somente se format for uma cadeia de caracteres de formato de TimeSpan padrão cujo valor seja "g" ou "G". As cadeias de caracteres de formato padrão "c", "t" e "T" usam as convenções de formatação da cultura invariável. 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.

O parâmetro formatProvider é uma implementação IFormatProvider que fornece informações específicas da cultura sobre o formato da cadeia de caracteres retornada se format for uma cadeia de caracteres de formato padrão. O parâmetro formatProvider pode ser qualquer um dos seguintes:

Se formatProvider for null, o objeto DateTimeFormatInfo associado à cultura atual será usado.

Confira também

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0