TimeSpan.TryParseExact Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
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 da cadeia de caracteres deve corresponder exatamente a um formato especificado.
Sobrecargas
TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) |
Converte a representação de cadeia de caracteres de um intervalo em seu equivalente de TimeSpan usando o formato, as informações de formato específicas à cultura e os estilos especificados. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado. |
TryParseExact(ReadOnlySpan<Char>, String[], IFormatProvider, TimeSpanStyles, TimeSpan) |
Converte a representação de intervalo especificada de um intervalo de tempo em seu equivalente de TimeSpan usando os formatos, as informações de formato específicas à cultura e os estilos especificados. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados. |
TryParseExact(ReadOnlySpan<Char>, ReadOnlySpan<Char>, IFormatProvider, TimeSpanStyles, TimeSpan) |
Converte a representação de intervalo especificada de um intervalo de tempo em seu equivalente de TimeSpan usando o formato especificado, as informações de formato específicas da cultura e os estilos e retorna um valor que indica se a conversão foi bem-sucedida. O formato de representação da 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 equivalente de TimeSpan usando os formatos e as informações de formato específicas à cultura especificados. O formato da representação da 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, as informações de formato específicas de cultura e os estilos. O formato da representação da 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 equivalente de TimeSpan usando os formatos e as informações de formato específicas à cultura especificados. O formato da representação da 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 equivalente de TimeSpan usando o formato e as informações de formato específicas à cultura especificados. O formato de representação da 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 hora em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura especificadas. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado. |
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 em seu equivalente de TimeSpan usando o formato, as informações de formato específicas à cultura e os estilos especificados. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.
public:
static bool TryParseExact(System::String ^ input, System::String ^ format, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (string input, string format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (string? input, string? format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (string? input, string format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
static member TryParseExact : string * string * IFormatProvider * System.Globalization.TimeSpanStyles * TimeSpan -> bool
Public Shared Function TryParseExact (input As String, format As String, formatProvider As IFormatProvider, styles As TimeSpanStyles, ByRef result As TimeSpan) As Boolean
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 personalizada que define o formato obrigatório de input
.
- formatProvider
- IFormatProvider
Um objeto que fornece informações de formatação específicas de cultura.
- styles
- TimeSpanStyles
Um ou mais valores de enumeração que indicam o estilo de input
.
- result
- TimeSpan
Quando esse método retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Exemplos
O exemplo a seguir usa o ParseExact(String, String, IFormatProvider) método para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias cadeias de caracteres de formato e culturas. Ele também usa o TimeSpanStyles.AssumeNegative valor para interpretar cada cadeia de caracteres como um intervalo de tempo negativo. A saída do exemplo ilustra que o TimeSpanStyles.AssumeNegative estilo afeta o valor retornado somente quando ele é usado com cadeias de caracteres de formato personalizado.
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
open System
open System.Globalization
do
// Parse hour:minute value with custom format specifier.
let intervalString = "17:14"
let format = "h\\:mm"
let culture = CultureInfo.CurrentCulture
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse hour:minute:second value with "g" specifier.
let intervalString = "17:14:48"
let format = "g"
let culture = CultureInfo.InvariantCulture
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse hours:minute.second value with custom format specifier.
let intervalString = "17:14:48.153"
let format = @"h\:mm\:ss\.fff"
let culture = null
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse days:hours:minute.second value with "G" specifier
// and current (en-US) culture.
let intervalString = "3:17:14:48.153"
let format = "G"
let culture = CultureInfo.CurrentCulture
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse days:hours:minute.second value with a custom format specifier.
let intervalString = "3:17:14:48.153"
let format = @"d\:hh\:mm\:ss\.fff"
let culture = null
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse days:hours:minute.second value with "G" specifier
// and fr-FR culture.
let intervalString = "3:17:14:48,153"
let format = "G"
let culture = new CultureInfo("fr-FR")
match TimeSpan.TryParseExact(intervalString, format, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse a single number using the "c" standard format string.
let intervalString = "12"
let format = "c"
match TimeSpan.TryParseExact(intervalString, format, null, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse a single number using the "%h" custom format string.
let format = "%h"
match TimeSpan.TryParseExact(intervalString, format, null, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {format}"
// Parse a single number using the "%s" custom format string.
let format = "%s"
match TimeSpan.TryParseExact(intervalString, format, null, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"'{intervalString}' ({format}) --> {interval}"
| _ ->
printfn $"Unable to parse '{intervalString}' using format {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
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
If TimeSpan.TryParseExact(intervalString, format,
culture, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' 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, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' Parse hours:minute.second value with custom format specifier.
intervalString = "17:14:48.153"
format = "h\:mm\:ss\.fff"
culture = Nothing
If TimeSpan.TryParseExact(intervalString, format,
culture, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' 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, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' 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
If TimeSpan.TryParseExact(intervalString, format,
culture, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' 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, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' Parse a single number using the "c" standard format string.
intervalString = "12"
format = "c"
If TimeSpan.TryParseExact(intervalString, format,
Nothing, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' Parse a single number using the "%h" custom format string.
format = "%h"
If TimeSpan.TryParseExact(intervalString, format,
Nothing, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
' Parse a single number using the "%s" custom format string.
format = "%s"
If TimeSpan.TryParseExact(intervalString, format,
Nothing, TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("'{0}' ({1}) --> {2}", intervalString, format, interval)
Else
Console.WriteLine("Unable to parse '{0}' using format {1}",
intervalString, format)
End If
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 TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido pelo parâmetro , exceto que os format
caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao ParseExact(String, String, IFormatProvider, TimeSpanStyles) método , exceto que ele não gera 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 que definem o formato exigido 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 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. O parâmetro formatProvider
pode ser um dos seguintes:
Um objeto CultureInfo que representa a cultura cujas convenções de formatação devem ser refletidas na cadeia de caracteres retornada. O objeto DateTimeFormatInfo retornado pela propriedade CultureInfo.DateTimeFormat define a formatação da cadeia de caracteres retornada.
Um objeto DateTimeFormatInfo que define a formatação da cadeia de caracteres retornada.
Um objeto personalizado que implementa a interface IFormatProvider. O método IFormatProvider.GetFormat retorna um objeto DateTimeFormatInfo que fornece informações de formatação.
Caso formatProvider
seja null
, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.
O styles
parâmetro afeta a interpretação de cadeias de caracteres analisadas usando cadeias de caracteres de formato personalizado. 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). 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
- Cadeias de caracteres de formato TimeSpan padrão
- Cadeias de caracteres de formato TimeSpan personalizado
Aplica-se a
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 equivalente de TimeSpan usando os formatos, as informações de formato específicas à cultura e os estilos especificados. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.
public:
static bool TryParseExact(ReadOnlySpan<char> input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (ReadOnlySpan<char> input, string?[]? formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
static member TryParseExact : ReadOnlySpan<char> * string[] * IFormatProvider * System.Globalization.TimeSpanStyles * TimeSpan -> bool
Public Shared Function TryParseExact (input As ReadOnlySpan(Of Char), formats As String(), formatProvider As IFormatProvider, styles As TimeSpanStyles, ByRef result As TimeSpan) As Boolean
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 retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Aplica-se a
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 equivalente de TimeSpan usando o formato especificado, as informações de formato específicas da cultura e os estilos e retorna um valor que indica se a conversão foi bem-sucedida. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.
public:
static bool TryParseExact(ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
static member TryParseExact : ReadOnlySpan<char> * ReadOnlySpan<char> * IFormatProvider * System.Globalization.TimeSpanStyles * TimeSpan -> bool
Public Shared Function TryParseExact (input As ReadOnlySpan(Of Char), format As ReadOnlySpan(Of Char), formatProvider As IFormatProvider, styles As TimeSpanStyles, ByRef result As TimeSpan) As Boolean
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 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 retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Aplica-se a
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 equivalente de TimeSpan usando os formatos e as informações de formato específicas à cultura especificados. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.
public:
static bool TryParseExact(System::String ^ input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (string input, string[] formats, IFormatProvider formatProvider, out TimeSpan result);
public static bool TryParseExact (string? input, string?[]? formats, IFormatProvider? formatProvider, out TimeSpan result);
public static bool TryParseExact (string? input, string[] formats, IFormatProvider? formatProvider, out TimeSpan result);
static member TryParseExact : string * string[] * IFormatProvider * TimeSpan -> bool
Public Shared Function TryParseExact (input As String, formats As String(), formatProvider As IFormatProvider, ByRef result As TimeSpan) As Boolean
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 de cultura.
- result
- TimeSpan
Quando esse método retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Exemplos
O exemplo a seguir chama o TryParseExact(String, String[], IFormatProvider, TimeSpan) método para converter cada elemento de uma matriz de cadeia de caracteres em um TimeSpan valor . O exemplo interpreta as cadeias de caracteres usando as convenções de formatação da cultura francês - 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 do intervalo de tempo interpretam um dígito único. Normalmente, um dígito único é 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 efetiva, a cadeia de caracteres de formato personalizado %h
deve preceder as outras cadeias de caracteres de formato na matriz formats
.
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
open System
open System.Globalization
let inputs =
[| "3"; "16:42"; "1:6:52:35.0625"
"1:6:52:35,0625" |]
let formats = [| "g"; "G"; "%h" |]
let culture = CultureInfo "fr-FR"
// Parse each string in inputs using formats and the fr-FR culture.
for input in inputs do
match TimeSpan.TryParseExact(input, formats, culture) with
| true, interval ->
printfn $"{input} --> {interval:c}"
| _ ->
printfn $"Unable to parse {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
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
If TimeSpan.TryParseExact(input, formats, culture, interval) Then
Console.WriteLine("{0} --> {1:c}", input, interval)
Else
Console.WriteLine("Unable to parse {0}", input)
End If
Next
End Sub
End Module
' 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 TryParseExact(String, String[], IFormatProvider, TimeSpan) método 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 formats
parâmetro , exceto que caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao ParseExact(String, String[], IFormatProvider) método , exceto que ele não gera uma exceção se a conversão falhar.
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
. 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 de formats
para que a operação de análise seja bem-sucedida. A operação de análise tenta comparar input
com cada elemento em formats
começando pelo primeiro elemento na matriz.
Importante
O TryParseExact método usa as convenções da cultura especificada pelo formatProvider
parâmetro somente se a cadeia de caracteres de formato usada para analisar for uma cadeia de caracteres input
de formato padrão TimeSpan 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. 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.
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. O parâmetro formatProvider
pode ser um dos seguintes:
Um objeto CultureInfo que representa a cultura cujas convenções de formatação devem ser refletidas na cadeia de caracteres retornada. O objeto DateTimeFormatInfo retornado pela propriedade CultureInfo.DateTimeFormat define a formatação da cadeia de caracteres retornada.
Um objeto DateTimeFormatInfo que define a formatação da cadeia de caracteres retornada.
Um objeto personalizado que implementa a interface IFormatProvider. O método IFormatProvider.GetFormat retorna um objeto DateTimeFormatInfo que fornece informações de formatação.
Caso formatProvider
seja null
, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.
Confira também
- Cadeias de caracteres de formato TimeSpan padrão
- Cadeias de caracteres de formato TimeSpan personalizado
Aplica-se a
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, as informações de formato específicas de cultura e os estilos. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.
public:
static bool TryParseExact(System::String ^ input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider, System::Globalization::TimeSpanStyles styles, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (string input, string[] formats, IFormatProvider formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (string? input, string?[]? formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
public static bool TryParseExact (string? input, string[] formats, IFormatProvider? formatProvider, System.Globalization.TimeSpanStyles styles, out TimeSpan result);
static member TryParseExact : string * string[] * IFormatProvider * System.Globalization.TimeSpanStyles * TimeSpan -> bool
Public Shared Function TryParseExact (input As String, formats As String(), formatProvider As IFormatProvider, styles As TimeSpanStyles, ByRef result As TimeSpan) As Boolean
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 retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Exemplos
O exemplo a seguir chama o TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) método para converter cada elemento de uma matriz de cadeia de caracteres em um TimeSpan valor . 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 do intervalo de tempo interpretam um dígito único. Normalmente, um dígito único é 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 efetiva, 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 TimeSpanStyles.AssumeNegative sinalizador especificado na chamada de método é usado somente ao analisar uma cadeia de caracteres com esse especificador de formato.
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
open System
open System.Globalization
let inputs =
[| "3"; "16:42"; "1:6:52:35.0625"
"1:6:52:35,0625" |]
let formats = [| "%h"; "g"; "G" |]
let culture = CultureInfo "fr-FR"
// Parse each string in inputs using formats and the fr-FR culture.
for input in inputs do
match TimeSpan.TryParseExact(input, formats, culture, TimeSpanStyles.AssumeNegative) with
| true, interval ->
printfn $"{input} --> {interval:c}"
| _ ->
printfn $"Unable to parse {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
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 fr-FR culture.
For Each input As String In inputs
If TimeSpan.TryParseExact(input, formats, culture,
TimeSpanStyles.AssumeNegative, interval) Then
Console.WriteLine("{0} --> {1:c}", input, interval)
Else
Console.WriteLine("Unable to parse {0}", input)
End If
Next
End Sub
End Module
' 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 TryParseExact(String, String[], IFormatProvider, TimeSpanStyles, TimeSpan) método 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 formats
parâmetro , exceto que caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao ParseExact(String, String[], IFormatProvider, TimeSpanStyles) método , exceto que ele não gera uma exceção se a conversão falhar.
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
. 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 de formats
para que a operação de análise seja bem-sucedida. A operação de análise tenta comparar input
com cada elemento em formats
começando pelo primeiro elemento na matriz.
Importante
O ParseExact método usa as convenções da cultura especificada pelo formatProvider
parâmetro somente se a cadeia de caracteres de formato usada para analisar for uma cadeia de caracteres input
de formato padrão TimeSpan 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. 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.
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. O parâmetro formatProvider
pode ser um dos seguintes:
Um objeto CultureInfo que representa a cultura cujas convenções de formatação devem ser refletidas na cadeia de caracteres retornada. O objeto DateTimeFormatInfo retornado pela propriedade CultureInfo.DateTimeFormat define a formatação da cadeia de caracteres retornada.
Um objeto DateTimeFormatInfo que define a formatação da cadeia de caracteres retornada.
Um objeto personalizado que implementa a interface IFormatProvider. O método IFormatProvider.GetFormat retorna um objeto DateTimeFormatInfo que fornece informações de formatação.
Caso formatProvider
seja null
, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.
O styles
parâmetro afeta a interpretação de cadeias de caracteres que são analisadas usando cadeias de caracteres de formato personalizado. 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). 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
- Cadeias de caracteres de formato TimeSpan padrão
- Cadeias de caracteres de formato TimeSpan personalizado
Aplica-se a
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 equivalente de TimeSpan usando os formatos e as informações de formato específicas à cultura especificados. O formato da representação da cadeia de caracteres deve corresponder exatamente a um dos formatos especificados.
public:
static bool TryParseExact(ReadOnlySpan<char> input, cli::array <System::String ^> ^ formats, IFormatProvider ^ formatProvider, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (ReadOnlySpan<char> input, string?[]? formats, IFormatProvider? formatProvider, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider formatProvider, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, string[] formats, IFormatProvider? formatProvider, out TimeSpan result);
static member TryParseExact : ReadOnlySpan<char> * string[] * IFormatProvider * TimeSpan -> bool
Public Shared Function TryParseExact (input As ReadOnlySpan(Of Char), formats As String(), formatProvider As IFormatProvider, ByRef result As TimeSpan) As Boolean
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 retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Aplica-se a
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 equivalente de TimeSpan usando o formato e as informações de formato específicas à cultura especificados. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.
public:
static bool TryParseExact(ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider ^ formatProvider, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider? formatProvider, out TimeSpan result);
public static bool TryParseExact (ReadOnlySpan<char> input, ReadOnlySpan<char> format, IFormatProvider formatProvider, out TimeSpan result);
static member TryParseExact : ReadOnlySpan<char> * ReadOnlySpan<char> * IFormatProvider * TimeSpan -> bool
Public Shared Function TryParseExact (input As ReadOnlySpan(Of Char), format As ReadOnlySpan(Of Char), formatProvider As IFormatProvider, ByRef result As TimeSpan) As Boolean
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 formatação 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.
- result
- TimeSpan
Quando esse método retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Aplica-se a
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 hora em seu equivalente de TimeSpan usando o formato e as informações de formato específicas da cultura especificadas. O formato de representação da cadeia de caracteres deve corresponder exatamente ao formato especificado.
public:
static bool TryParseExact(System::String ^ input, System::String ^ format, IFormatProvider ^ formatProvider, [Runtime::InteropServices::Out] TimeSpan % result);
public static bool TryParseExact (string input, string format, IFormatProvider formatProvider, out TimeSpan result);
public static bool TryParseExact (string? input, string? format, IFormatProvider? formatProvider, out TimeSpan result);
public static bool TryParseExact (string? input, string format, IFormatProvider? formatProvider, out TimeSpan result);
static member TryParseExact : string * string * IFormatProvider * TimeSpan -> bool
Public Shared Function TryParseExact (input As String, format As String, formatProvider As IFormatProvider, ByRef result As TimeSpan) As Boolean
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 personalizada que define o formato obrigatório de input
.
- formatProvider
- IFormatProvider
Um objeto que fornece informações de formatação específicas da cultura.
- result
- TimeSpan
Quando esse método retorna, contém um objeto que representa o intervalo de tempo especificado por input
ou Zero caso a conversão falhe. Este parâmetro é passado não inicializado.
Retornos
true
caso input
tenha sido convertido com êxito; do contrário, false
.
Exemplos
O exemplo a seguir usa o TryParseExact(String, String, IFormatProvider, TimeSpanStyles, TimeSpan) método para analisar várias representações de cadeia de caracteres de intervalos de tempo usando várias cadeias de caracteres de formato e culturas.
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
open System
open System.Globalization
do
// Parse hour:minute value with "g" specifier current culture.
let intervalString = "17:14"
let format = "g"
let culture = CultureInfo.CurrentCulture
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse hour:minute:second value with "G" specifier.
let intervalString = "17:14:48"
let format = "G"
let culture = CultureInfo.InvariantCulture
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse hours:minute.second value with "G" specifier
// and current (en-US) culture.
let intervalString = "17:14:48.153"
let format = "G"
let culture = CultureInfo.CurrentCulture
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse days:hours:minute.second value with "G" specifier
// and current (en-US) culture.
let intervalString = "3:17:14:48.153"
let format = "G"
let culture = CultureInfo.CurrentCulture
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse days:hours:minute.second value with "G" specifier
// and fr-FR culture.
let intervalString = "3:17:14:48.153"
let format = "G"
let culture = new CultureInfo("fr-FR")
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse days:hours:minute.second value with "G" specifier
// and fr-FR culture.
let intervalString = "3:17:14:48,153"
let format = "G"
match TimeSpan.TryParseExact(intervalString, format, culture) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse a single number using the "c" standard format string.
let intervalString = "12"
let format = "c"
match TimeSpan.TryParseExact(intervalString, format, null) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse a single number using the "%h" custom format string.
let format = "%h"
match TimeSpan.TryParseExact(intervalString, format, null) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {intervalString}"
// Parse a single number using the "%s" custom format string.
let format = "%s"
match TimeSpan.TryParseExact(intervalString, format, null) with
| true, interval ->
printfn $"'{intervalString}' --> {interval}"
| _ ->
printfn $"Unable to parse {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
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
If TimeSpan.TryParseExact(intervalString, format, culture, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' Parse hour:minute:second value with "G" specifier.
intervalString = "17:14:48"
format = "G"
culture = CultureInfo.InvariantCulture
If TimeSpan.TryParseExact(intervalString, format, culture, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' 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, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' 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, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' 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, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' 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, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' Parse a single number using the "c" standard format string.
intervalString = "12"
format = "c"
If TimeSpan.TryParseExact(intervalString, format, Nothing, interval)
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' Parse a single number using the "%h" custom format string.
format = "%h"
If TimeSpan.TryParseExact(intervalString, format, Nothing, interval)
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
' Parse a single number using the "%s" custom format string.
format = "%s"
If TimeSpan.TryParseExact(intervalString, format, Nothing, interval) Then
Console.WriteLine("'{0}' --> {1}", intervalString, interval)
Else
Console.WriteLine("Unable to parse {0}", intervalString)
End If
End Sub
End Module
' 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 TryParseExact(String, String, IFormatProvider, TimeSpan) método analisa a representação de cadeia de caracteres de um intervalo de tempo, que deve estar no formato definido pelo parâmetro , exceto que os format
caracteres de espaço em branco à esquerda e à direita são ignorados. Esse método é semelhante ao ParseExact(String, String, IFormatProvider) método , exceto que ele não gera 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 que definem o formato exigido 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 TryParseExact(String, String, IFormatProvider, TimeSpan) método usa as convenções da cultura especificadas pelo formatProvider
parâmetro somente se format
for uma cadeia de caracteres de formato padrão TimeSpan 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. 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.
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. O parâmetro formatProvider
pode ser um dos seguintes:
Um objeto CultureInfo que representa a cultura cujas convenções de formatação devem ser refletidas na cadeia de caracteres retornada. O objeto DateTimeFormatInfo retornado pela propriedade CultureInfo.DateTimeFormat define a formatação da cadeia de caracteres retornada.
Um objeto DateTimeFormatInfo que define a formatação da cadeia de caracteres retornada.
Um objeto personalizado que implementa a interface IFormatProvider. O método IFormatProvider.GetFormat retorna um objeto DateTimeFormatInfo que fornece informações de formatação.
Caso formatProvider
seja null
, o objeto DateTimeFormatInfo que está associado à cultura atual é usado.
Confira também
- Cadeias de caracteres de formato TimeSpan padrão
- Cadeias de caracteres de formato TimeSpan personalizado
Aplica-se a
Comentários
https://aka.ms/ContentUserFeedback.
Brevemente: Ao longo de 2024, vamos descontinuar progressivamente o GitHub Issues como mecanismo de feedback para conteúdos e substituí-lo por um novo sistema de feedback. Para obter mais informações, veja:Submeter e ver comentários