DateTime.TryParseExact Method (String, String, IFormatProvider, DateTimeStyles, DateTime%)

Microsoft Silverlight will reach end of support after October 2021. Learn more.

Converts the specified string representation of a date and time to its DateTime equivalent using the specified format, culture-specific format information, and style. The format of the string representation must match the specified format exactly. The method returns a value that indicates whether the conversion succeeded.

Namespace:  System
Assembly:  mscorlib (in mscorlib.dll)

Syntax

'Declaration
Public Shared Function TryParseExact ( _
    s As String, _
    format As String, _
    provider As IFormatProvider, _
    style As DateTimeStyles, _
    <OutAttribute> ByRef result As DateTime _
) As Boolean
public static bool TryParseExact(
    string s,
    string format,
    IFormatProvider provider,
    DateTimeStyles style,
    out DateTime result
)

Parameters

  • s
    Type: System.String
    A string that contains a date and time to convert.
  • provider
    Type: System.IFormatProvider
    An object that supplies culture-specific formatting information about s.
  • result
    Type: System.DateTime%
    When this method returns, contains the DateTime value that is equivalent to the date and time contained in s, if the conversion succeeded, or DateTime.MinValue if the conversion failed. The conversion fails if either the s or format parameter is nulla null reference (Nothing in Visual Basic), is an empty string, or does not contain a date and time that correspond to the pattern specified in format. This parameter is passed uninitialized.

Return Value

Type: System.Boolean
true if the s parameter was converted successfully; otherwise, false.

Exceptions

Exception Condition
ArgumentException

styles is not a valid DateTimeStyles value.

-or-

styles contains an invalid combination of DateTimeStyles values (for example, both AssumeLocal and AssumeUniversal).

Remarks

The DateTime.TryParseExact(String, String, IFormatProvider, DateTimeStyles, DateTime%) method parses the string representation of a date, which must be in the format defined by the format parameter. It is similar to the DateTime.ParseExact(String, String, IFormatProvider, DateTimeStyles) method, except that the TryParseExact(String, String, IFormatProvider, DateTimeStyles, DateTime%) method does not throw an exception if the conversion fails.

The s parameter contains the date and time to parse and must be in a format defined by the format parameter. If date, time, and time zone elements are present in s, they must also appear in the order specified by format. If format defines a date with no time element and the parse operation succeeds, the resulting DateTime value has a time of midnight (00:00:00). If format defines a time with no date element and the parse operation succeeds, the resulting DateTime value by default has a date of DateTime.Now.Date, or it has a date of DateTime.MinValue.Date if styles includes the DateTimeStyles.NoCurrentDateDefault flag. The style parameter determines whether the s parameter can contain leading, inner, or trailing white space characters.

If s contains no time zone information, the Kind property of the returned DateTime object is DateTimeKind.Unspecified. This behavior can be changed by using the DateTimeStyles.AssumeLocal flag, which returns a DateTime value whose Kind property is DateTimeKind.Local, or by using the DateTimeStyles.AssumeUniversal and DateTimeStyles.AdjustToUniversal flags, which returns a DateTime value whose Kind property is DateTimeKind.Utc. If s contains time zone information, the time is converted to local time, if necessary, and the Kind property of the returned DateTime object is set to DateTimeKind.Local. This behavior can be changed by using the DateTimeStyles.RoundtripKind flag to not convert Coordinated Universal Time (UTC) to a local time and set the Kind property to DateTimeKind.Utc.

The format parameter contains a pattern that corresponds to the expected format of the s parameter. The pattern in the format parameter consists of one or more custom format specifiers from the Custom Date and Time Format Strings table, or a single standard format specifier, which identifies a predefined pattern, from the Standard Date and Time Format Strings table.

If you do not use date or time separators in a custom format pattern, use the invariant culture for the provider parameter and the widest form of each custom format specifier. For example, if you want to specify hours in the pattern, specify the wider form, "HH", instead of the narrower form, "H".

NoteNote:

Rather than requiring that s conform to a single format for the parse operation to succeed, you can call the DateTime.TryParseExact(String, array<String[], IFormatProvider, DateTimeStyles, DateTime%) method and specify multiple permitted formats. This makes the parse operation more likely to succeed.

The particular date and time symbols and strings (such as the names of the days of the week in a particular language) used in s are defined by the provider parameter, as is the precise format of s if format is a standard format specifier string. The provider parameter can be any of the following:

If provider is nulla null reference (Nothing in Visual Basic), the CultureInfo object that corresponds to the current culture is used.

The styles parameter includes one or more members of the DateTimeStyles enumeration that determine whether and where white space not defined by format can appear in s and that control the precise behavior of the parse operation. The following table describes how each member of the DateTimeStyles enumeration affects the operation of the TryParseExact(String, String, IFormatProvider, DateTimeStyles, DateTime%) method.

DateTimeStyles member

Description

AdjustToUniversal

Parses s and, if necessary, converts it to UTC. If s includes a time zone offset, or if s contains no time zone information but styles includes the DateTimeStyles.AssumeLocal flag, the method parses the string, calls ToUniversalTime to convert the returned DateTime value to UTC, and sets the Kind property to DateTimeKind.Utc. If s indicates that it represents UTC, or if s does not contain time zone information but styles includes the DateTimeStyles.AssumeUniversal flag, the method parses the string, performs no time zone conversion on the returned DateTime value, and sets the Kind property to DateTimeKind.Utc. In all other cases, the flag has no effect.

AllowInnerWhite

Specifies that white space not defined by format can appear between any individual date or time element.

AllowLeadingWhite

Specifies that white space not defined by format can appear at the beginning of s.

AllowTrailingWhite

Specifies that white space not defined by format can appear at the end of s.

AllowWhiteSpaces

Specifies that s may contain leading, inner, and trailing white spaces not defined by format.

AssumeLocal

Specifies that if s lacks any time zone information, it is assumed to represent a local time. Unless the DateTimeStyles.AdjustToUniversal flag is present, the Kind property of the returned DateTime value is set to DateTimeKind.Local.

AssumeUniversal

Specifies that if s lacks any time zone information, it is assumed to represent UTC. Unless the DateTimeStyles.AdjustToUniversal flag is present, the method converts the returned DateTime value from UTC to local time and sets its Kind property to DateTimeKind.Local.

NoCurrentDateDefault

If s contains time without date information, the date of the return value is set to DateTime.MinValue.Date.

None

The s parameter is parsed using default values. No white space other than that present in format is allowed. If s lacks a date component, the date of the returned DateTime value is set to 1/1/0001. If s contains no time zone information, the Kind property of the returned DateTime object is set to DateTimeKind.Unspecified. If time zone information is present in s, the time is converted to local time and the Kind property of the returned DateTime object is set to DateTimeKind.Local.

RoundtripKind

For strings that contain time zone information, tries to prevent the conversion to a DateTime value with its Kind property set to DateTimeKind.Local. This flag primarily prevents the conversion of UTC times to local times.

Examples

The following example demonstrates the DateTime.TryParseExact(String, String, IFormatProvider, DateTimeStyles, DateTime%) method. Note that the string " 5/01/2009 8:30 AM" cannot be parsed successfully when the styles parameter equals DateTimeStyles.None because leading spaces are not allowed by format. Additionally, the string "5/01/2009 09:00" cannot be parsed successfully with a format of "MM/dd/yyyy hh:mm" because the date string does not precede the month number with a leading zero, as format requires.

Dim enUS As New CultureInfo("en-US")
Dim dateString As String
Dim dateValue As Date

' Parse date with no style flags.
dateString = " 5/01/2009 8:30 AM"
If Date.TryParseExact(dateString, "g", enUS, _
                      DateTimeStyles.None, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If
' Allow a leading space in the date string.
If Date.TryParseExact(dateString, "g", enUS, _
                      DateTimeStyles.AllowLeadingWhite, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If

' Use custom formats with M and MM.
dateString = "5/01/2009 09:00"
If Date.TryParseExact(dateString, "M/dd/yyyy hh:mm", enUS, _
                      DateTimeStyles.None, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If
' Allow a leading space in the date string.
If Date.TryParseExact(dateString, "MM/dd/yyyy hh:mm", enUS, _
                      DateTimeStyles.None, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If

' Parse a string with time zone information.
dateString = "05/01/2009 01:30:42 PM -05:00"
If Date.TryParseExact(dateString, "MM/dd/yyyy hh:mm:ss tt zzz", enUS, _
                      DateTimeStyles.None, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If
' Allow a leading space in the date string.
If Date.TryParseExact(dateString, "MM/dd/yyyy hh:mm:ss tt zzz", enUS, _
                      DateTimeStyles.AdjustToUniversal, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If

' Parse a string represengting UTC.
dateString = "2008-06-11T16:11:20.0904778Z"
If Date.TryParseExact(dateString, "o", CultureInfo.InvariantCulture, _
                               DateTimeStyles.None, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If

If Date.TryParseExact(dateString, "o", CultureInfo.InvariantCulture, _
                      DateTimeStyles.RoundtripKind, dateValue) Then
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).", dateString, dateValue, _
                     dateValue.Kind) & vbCrLf
Else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.", dateString) & vbCrLf
End If
' The example displays the following output:
'    ' 5/01/2009 8:30 AM' is not in an acceptable format.
'    Converted ' 5/01/2009 8:30 AM' to 5/1/2009 8:30:00 AM (Unspecified).
'    Converted '5/01/2009 09:00' to 5/1/2009 9:00:00 AM (Unspecified).
'    '5/01/2009 09:00' is not in an acceptable format.
'    Converted '05/01/2009 01:30:42 PM -05:00' to 5/1/2009 11:30:42 AM (Local).
'    Converted '05/01/2009 01:30:42 PM -05:00' to 5/1/2009 6:30:42 PM (Utc).
'    Converted '2008-06-11T16:11:20.0904778Z' to 6/11/2008 9:11:20 AM (Local).
'    Converted '2008-06-11T16:11:20.0904778Z' to 6/11/2008 4:11:20 PM (Utc).
CultureInfo enUS = new CultureInfo("en-US");
string dateString;
DateTime dateValue;

// Parse date with no style flags.
dateString = " 5/01/2009 8:30 AM";
if (DateTime.TryParseExact(dateString, "g", enUS,
                           DateTimeStyles.None, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Allow a leading space in the date string.
if (DateTime.TryParseExact(dateString, "g", enUS,
                           DateTimeStyles.AllowLeadingWhite, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Use custom formats with M and MM.
dateString = "5/01/2009 09:00";
if (DateTime.TryParseExact(dateString, "M/dd/yyyy hh:mm", enUS,
                           DateTimeStyles.None, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Allow a leading space in the date string.
if (DateTime.TryParseExact(dateString, "MM/dd/yyyy hh:mm", enUS,
                        DateTimeStyles.None, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Parse a string with time zone information.
dateString = "05/01/2009 01:30:42 PM -05:00";
if (DateTime.TryParseExact(dateString, "MM/dd/yyyy hh:mm:ss tt zzz", enUS,
                        DateTimeStyles.None, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Allow a leading space in the date string.
if (DateTime.TryParseExact(dateString, "MM/dd/yyyy hh:mm:ss tt zzz", enUS,
                        DateTimeStyles.AdjustToUniversal, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// Parse a string represengting UTC.
dateString = "2008-06-11T16:11:20.0904778Z";
if (DateTime.TryParseExact(dateString, "o", CultureInfo.InvariantCulture,
                               DateTimeStyles.None, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

if (DateTime.TryParseExact(dateString, "o", CultureInfo.InvariantCulture,
                           DateTimeStyles.RoundtripKind, out dateValue))
   outputBlock.Text += String.Format("Converted '{0}' to {1} ({2}).\n", dateString, dateValue,
                     dateValue.Kind);
else
   outputBlock.Text += String.Format("'{0}' is not in an acceptable format.\n", dateString);

// The example displays the following output:
//    ' 5/01/2009 8:30 AM' is not in an acceptable format.
//    Converted ' 5/01/2009 8:30 AM' to 5/1/2009 8:30:00 AM (Unspecified).
//    Converted '5/01/2009 09:00' to 5/1/2009 9:00:00 AM (Unspecified).
//    '5/01/2009 09:00' is not in an acceptable format.
//    Converted '05/01/2009 01:30:42 PM -05:00' to 5/1/2009 11:30:42 AM (Local).
//    Converted '05/01/2009 01:30:42 PM -05:00' to 5/1/2009 6:30:42 PM (Utc).
//    Converted '2008-06-11T16:11:20.0904778Z' to 6/11/2008 9:11:20 AM (Local).
//    Converted '2008-06-11T16:11:20.0904778Z' to 6/11/2008 4:11:20 PM (Utc).

Version Information

Silverlight

Supported in: 5, 4, 3

Silverlight for Windows Phone

Supported in: Windows Phone OS 7.1, Windows Phone OS 7.0

XNA Framework

Supported in: Xbox 360, Windows Phone OS 7.0

Platforms

For a list of the operating systems and browsers that are supported by Silverlight, see Supported Operating Systems and Browsers.