Instanziieren eines "DateTimeOffset"-Objekts
Die DateTimeOffset-Klasse bietet eine Reihe von Möglichkeiten, neue DateTimeOffset-Werte zu erstellen. Viele dieser Möglichkeiten stimmen direkt mit den Methoden zum Instanziieren neuer DateTime-Werte überein, ermöglichen für die Datums- und Uhrzeitwerte jedoch zusätzlich die Angabe eines Offsets von der koordinierten Weltzeit (UTC). Zum Instanziieren eines DateTimeOffset-Werts sind insbesondere die folgenden Methoden verfügbar:
Verwenden eines Datums- und Uhrzeitliterals
Aufrufen eines DateTimeOffset-Konstruktors
Implizites Konvertieren eines Werts in einen DateTimeOffset-Wert
Analysieren der Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts
Dieses Thema enthält detaillierte Informationen und Codebeispiele zum Instanziieren neuer DateTimeOffset-Werte mit diesen Methoden.
Datums- und Uhrzeitliterale
Eine der gebräuchlichsten Methoden zum Instanziieren eines DateTime-Werts ist es, den Datums- und Uhrzeitwert als hartcodierten Literalwert bereitzustellen, sofern dies von der jeweiligen Sprache unterstützt wird. Mit dem folgenden Visual Basic-Code wird z. B. ein DateTime-Objekt mit dem Wert 1. Januar 2008, 10:00 Uhr erstellt.
Dim literalDate1 As Date = #05/01/2008 8:06:32 AM#
Console.WriteLine(literalDate1.ToString() )
' Displays:
' 5/1/2008 8:06:32 AM
DateTimeOffset-Werte können ebenfalls mit Datums- und Uhrzeitliteralen initialisiert werden, wenn die verwendeten Sprachen DateTime-Literale unterstützen. Mit dem folgenden Visual Basic-Code wird z. B. ein DateTimeOffset-Objekt erstellt.
Dim literalDate As DateTimeOffset = #05/01/2008 8:06:32 AM#
Console.WriteLine(literalDate.ToString() )
' Displays:
' 5/1/2008 8:06:32 AM -07:00
Wie die Konsolenausgabe zeigt, wird dem auf diese Weise erstellten DateTimeOffset-Wert der Offset der lokalen Zeitzone zugewiesen. Das bedeutet, dass ein mit einem Zeichenliteral zugewiesener DateTimeOffset-Wert keinen bestimmten Zeitpunkt identifiziert, wenn der Code auf verschiedenen Computern ausgeführt wird.
"DateTimeOffset"-Konstruktoren
Der DateTimeOffset-Typ definiert sechs Konstruktoren. Vier von ihnen entsprechen DateTime-Konstruktoren mit einem zusätzlichen Parameter vom Typ TimeSpan, der den Offset des Datums- und Uhrzeitwerts von der koordinierten Weltzeit definiert. Sie ermöglichen Ihnen die Definition eines DateTimeOffset-Werts auf Basis der Werte seiner einzelnen Datums- und Uhrzeitkomponenten. Im folgenden Code werden diese vier Konstruktoren z. B. zum Instanziieren von DateTimeOffset-Objekten mit den identischen Werten 7/1/2008 12:05 AM +01:00 verwendet.
Dim dateAndTime As DateTimeOffset
' Instantiate date and time using years, months, days,
' hours, minutes, and seconds
dateAndTime = New DateTimeOffset(2008, 5, 1, 8, 6, 32, _
New TimeSpan(1, 0, 0))
Console.WriteLine(dateAndTime)
' Instantiate date and time using years, months, days,
' hours, minutes, seconds, and milliseconds
dateAndTime = New DateTimeOffset(2008, 5, 1, 8, 6, 32, 545, _
New TimeSpan(1, 0, 0))
Console.WriteLine("{0} {1}", dateAndTime.ToString("G"), _
dateAndTime.ToString("zzz"))
' Instantiate date and time using Persian calendar with years,
' months, days, hours, minutes, seconds, and milliseconds
dateAndTime = New DateTimeOffset(1387, 2, 12, 8, 6, 32, 545, New PersianCalendar, New TimeSpan(1, 0, 0))
' Note that the console output displays the date in the Gregorian
' calendar, not the Persian calendar.
Console.WriteLine("{0} {1}", dateAndTime.ToString("G"), _
dateAndTime.ToString("zzz"))
' Instantiate date and time using number of ticks
' 05/01/2008 8:06:32 AM is 633,452,259,920,000,000 ticks
dateAndTime = New DateTimeOffset(633452259920000000, New TimeSpan(1, 0, 0))
Console.WriteLine(dateAndTime)
' The example displays the following output to the console:
' 5/1/2008 8:06:32 AM +01:00
' 5/1/2008 8:06:32 AM +01:00
' 5/1/2008 8:06:32 AM +01:00
' 5/1/2008 8:06:32 AM +01:00
DateTimeOffset dateAndTime;
// Instantiate date and time using years, months, days,
// hours, minutes, and seconds
dateAndTime = new DateTimeOffset(2008, 5, 1, 8, 6, 32,
new TimeSpan(1, 0, 0));
Console.WriteLine(dateAndTime);
// Instantiate date and time using years, months, days,
// hours, minutes, seconds, and milliseconds
dateAndTime = new DateTimeOffset(2008, 5, 1, 8, 6, 32, 545,
new TimeSpan(1, 0, 0));
Console.WriteLine("{0} {1}", dateAndTime.ToString("G"),
dateAndTime.ToString("zzz"));
// Instantiate date and time using Persian calendar with years,
// months, days, hours, minutes, seconds, and milliseconds
dateAndTime = new DateTimeOffset(1387, 2, 12, 8, 6, 32, 545,
new PersianCalendar(),
new TimeSpan(1, 0, 0));
// Note that the console output displays the date in the Gregorian
// calendar, not the Persian calendar.
Console.WriteLine("{0} {1}", dateAndTime.ToString("G"),
dateAndTime.ToString("zzz"));
// Instantiate date and time using number of ticks
// 05/01/2008 8:06:32 AM is 633,452,259,920,000,000 ticks
dateAndTime = new DateTimeOffset(633452259920000000, new TimeSpan(1, 0, 0));
Console.WriteLine(dateAndTime);
// The example displays the following output to the console:
// 5/1/2008 8:06:32 AM +01:00
// 5/1/2008 8:06:32 AM +01:00
// 5/1/2008 8:06:32 AM +01:00
// 5/1/2008 8:06:32 AM +01:00
Beachten Sie, dass wenn der Wert des DateTimeOffset-Objekts, das mit einem PersianCalendar-Objekt als eines der Argumente für dessen Konstruktor instanziiert wird, auf der Konsole angezeigt wird, dieser als Datum im gregorianischen Kalender und nicht als Datum im persischen Kalender ausgedrückt wird. Ein Beispiel zur Ausgabe eines Datums mit dem persischen Kalender finden Sie im Thema PersianCalendar.
Mit den anderen beiden Konstruktoren wird ein DateTimeOffset-Objekt aus einem DateTime-Wert erstellt. Der erste verfügt über einen einzigen Parameter, dem DateTime-Wert zum Konvertieren in einen DateTimeOffset-Wert. Der Offset des resultierenden DateTimeOffset-Werts hängt von der Kind-Eigenschaft des einzigen Parameters des Konstruktors ab. Wenn der Wert DateTimeKind.Utc lautet, entspricht der Offset TimeSpan.Zero. Andernfalls entspricht der Offset dem der lokalen Zeitzone. Das folgende Beispiel zeigt die Verwendung dieses Konstruktors zum Instanziieren von DateTimeOffset-Objekten, die die koordinierte Weltzeit und die lokale Zeitzone darstellen:
' Declare date; Kind property is DateTimeKind.Unspecified
Dim sourceDate As Date = #5/1/2008 8:30 AM#
Dim targetTime As DateTimeOffset
' Instantiate a DateTimeOffset value from a UTC time
Dim utcTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Utc)
targetTime = New DateTimeOffset(utcTime)
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM +00:00
' Because the Kind property is DateTimeKind.Utc,
' the offset is TimeSpan.Zero.
' Instantiate a DateTimeOffset value from a local time
Dim localTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Local)
targetTime = New DateTimeOffset(localTime)
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM -07:00
' Because the Kind property is DateTimeKind.Local,
' the offset is that of the local time zone.
' Instantiate a DateTimeOffset value from an unspecified time
targetTime = New DateTimeOffset(sourceDate)
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM -07:00
' Because the Kind property is DateTimeKind.Unspecified,
' the offset is that of the local time zone.
'
// Declare date; Kind property is DateTimeKind.Unspecified
DateTime sourceDate = new DateTime(2008, 5, 1, 8, 30, 0);
DateTimeOffset targetTime;
// Instantiate a DateTimeOffset value from a UTC time
DateTime utcTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Utc);
targetTime = new DateTimeOffset(utcTime);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM +00:00
// Because the Kind property is DateTimeKind.Utc,
// the offset is TimeSpan.Zero.
// Instantiate a DateTimeOffset value from a UTC time with a zero offset
targetTime = new DateTimeOffset(utcTime, TimeSpan.Zero);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM +00:00
// Because the Kind property is DateTimeKind.Utc,
// the call to the constructor succeeds
// Instantiate a DateTimeOffset value from a UTC time with a negative offset
try
{
targetTime = new DateTimeOffset(utcTime, new TimeSpan(-2, 0, 0));
Console.WriteLine(targetTime);
}
catch (ArgumentException)
{
Console.WriteLine("Attempt to create DateTimeOffset value from {0} failed.",
targetTime);
}
// Throws exception and displays the following to the console:
// Attempt to create DateTimeOffset value from 5/1/2008 8:30:00 AM +00:00 failed.
// Instantiate a DateTimeOffset value from a local time
DateTime localTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Local);
targetTime = new DateTimeOffset(localTime);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -07:00
// Because the Kind property is DateTimeKind.Local,
// the offset is that of the local time zone.
// Instantiate a DateTimeOffset value from an unspecified time
targetTime = new DateTimeOffset(sourceDate);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -07:00
// Because the Kind property is DateTimeKind.Unspecified,
// the offset is that of the local time zone.
Hinweis |
---|
Das Aufrufen der Überladung des DateTimeOffset-Konstruktors, der über einen einzigen DateTime-Parameter verfügt, entspricht dem impliziten Konvertieren eines DateTime-Werts in einen DateTimeOffset-Wert. |
Der zweite Konstruktor, der ein DateTimeOffset-Objekt aus einem DateTime-Wert erstellt, verfügt über zwei Parameters: den zu konvertierenden DateTime-Wert und einen TimeSpan-Wert, der den Offset des Datums- und Uhrzeitwerts von der koordinierten Weltzeit darstellt. Dieser Offsetwert muss der Kind-Eigenschaft des ersten Parameters des Konstruktors entsprechen. Andernfalls wird eine ArgumentException ausgelöst. Wenn die Kind-Eigenschaft des ersten Parameters DateTimeKind.Utc lautet, muss der Wert des zweiten Parameters TimeSpan.Zero entsprechen. Wenn die Kind-Eigenschaft des ersten Parameters DateTimeKind.Local lautet, muss der Wert des zweiten Parameters dem Offset der lokalen Zeitzone entsprechen. Wenn die Kind-Eigenschaft des ersten Parameters DateTimeKind.Unspecified lautet, kann der Offset einem beliebigen gültigen Wert entsprechen. Der folgende Code zeigt Aufrufe dieses Konstruktors zum Konvertieren von DateTime-Werten in DateTimeOffset-Werte.
Dim sourceDate As Date = #5/1/2008 8:30 AM#
Dim targetTime As DateTimeOffset
' Instantiate a DateTimeOffset value from a UTC time with a zero offset.
Dim utcTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Utc)
targetTime = New DateTimeOffset(utcTime, TimeSpan.Zero)
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM +00:00
' Because the Kind property is DateTimeKind.Utc,
' the call to the constructor succeeds.
' Instantiate a DateTimeOffset value from a UTC time with a non-zero offset.
Try
targetTime = New DateTimeOffset(utcTime, New TimeSpan(-2, 0, 0))
Console.WriteLine(targetTime)
Catch e As ArgumentException
Console.WriteLine("Attempt to create DateTimeOffset value from {0} failed.", _
utcTime)
End Try
' Throws exception and displays the following to the console:
' Attempt to create DateTimeOffset value from 5/1/2008 8:30:00 AM failed.
' Instantiate a DateTimeOffset value from a local time with
' the offset of the local time zone.
Dim localTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Local)
targetTime = New DateTimeOffset(localTime, _
TimeZoneInfo.Local.GetUtcOffset(localTime))
Console.WriteLine(targetTime)
' Because the Kind property is DateTimeKind.Local and the offset matches
' that of the local time zone, the call to the constructor succeeds.
' Instantiate a DateTimeOffset value from a local time with a zero offset.
Try
targetTime = New DateTimeOffset(localTime, TimeSpan.Zero)
Console.WriteLine(targetTime)
Catch e As ArgumentException
Console.WriteLine("Attempt to create DateTimeOffset value from {0} failed.", _
localTime)
End Try
' Throws exception and displays the following to the console:
' Attempt to create DateTimeOffset value from 5/1/2008 8:30:00 AM failed.
' Instantiate a DateTimeOffset value with an arbitary time zone.
Dim timeZoneName As String = "Central Standard Time"
Dim offset As TimeSpan = TimeZoneInfo.FindSystemTimeZoneById(timeZoneName). _
GetUtcOffset(sourceDate)
targetTime = New DateTimeOffset(sourceDate, offset)
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM -05:00
DateTime sourceDate = new DateTime(2008, 5, 1, 8, 30, 0);
DateTimeOffset targetTime;
// Instantiate a DateTimeOffset value from a UTC time with a zero offset.
DateTime utcTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Utc);
targetTime = new DateTimeOffset(utcTime, TimeSpan.Zero);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM +00:00
// Because the Kind property is DateTimeKind.Utc,
// the call to the constructor succeeds
// Instantiate a DateTimeOffset value from a UTC time with a non-zero offset.
try
{
targetTime = new DateTimeOffset(utcTime, new TimeSpan(-2, 0, 0));
Console.WriteLine(targetTime);
}
catch (ArgumentException)
{
Console.WriteLine("Attempt to create DateTimeOffset value from {0} failed.",
utcTime);
}
// Throws exception and displays the following to the console:
// Attempt to create DateTimeOffset value from 5/1/2008 8:30:00 AM failed.
// Instantiate a DateTimeOffset value from a local time with
// the offset of the local time zone
DateTime localTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Local);
targetTime = new DateTimeOffset(localTime,
TimeZoneInfo.Local.GetUtcOffset(localTime));
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -07:00
// Because the Kind property is DateTimeKind.Local and the offset matches
// that of the local time zone, the call to the constructor succeeds.
// Instantiate a DateTimeOffset value from a local time with a zero offset.
try
{
targetTime = new DateTimeOffset(localTime, TimeSpan.Zero);
Console.WriteLine(targetTime);
}
catch (ArgumentException)
{
Console.WriteLine("Attempt to create DateTimeOffset value from {0} failed.",
localTime);
}
// Throws exception and displays the following to the console:
// Attempt to create DateTimeOffset value from 5/1/2008 8:30:00 AM failed.
// Instantiate a DateTimeOffset value with an arbitary time zone.
string timeZoneName = "Central Standard Time";
TimeSpan offset = TimeZoneInfo.FindSystemTimeZoneById(timeZoneName).
GetUtcOffset(sourceDate);
targetTime = new DateTimeOffset(sourceDate, offset);
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -05:00
Implizite Typkonvertierung
Der DateTimeOffset-Typ unterstützt eine implizite Typkonvertierung: von einem DateTime-Wert in einen DateTimeOffset-Wert. Eine implizite Typkonvertierung ist eine Konvertierung von einem Typ in einen anderen, die keine explizite Typumwandlung (in C#) oder Konvertierung (in Visual Basic) erfordert und bei der keine Informationen verloren gehen. Sie ermöglicht Code wie den folgenden:
Dim targetTime As DateTimeOffset
' The Kind property of sourceDate is DateTimeKind.Unspecified
Dim sourceDate As Date = #5/1/2008 8:30 AM#
targetTime = sourceDate
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM -07:00
' define a UTC time (Kind property is DateTimeKind.Utc)
Dim utcTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Utc)
targetTime = utcTime
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM +00:00
' Define a local time (Kind property is DateTimeKind.Local)
Dim localTime As Date = Date.SpecifyKind(sourceDate, DateTimeKind.Local)
targetTime = localTime
Console.WriteLine(targetTime)
' Displays 5/1/2008 8:30:00 AM -07:00
DateTimeOffset targetTime;
// The Kind property of sourceDate is DateTimeKind.Unspecified
DateTime sourceDate = new DateTime(2008, 5, 1, 8, 30, 0);
targetTime = sourceDate;
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -07:00
// define a UTC time (Kind property is DateTimeKind.Utc)
DateTime utcTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Utc);
targetTime = utcTime;
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM +00:00
// Define a local time (Kind property is DateTimeKind.Local)
DateTime localTime = DateTime.SpecifyKind(sourceDate, DateTimeKind.Local);
targetTime = localTime;
Console.WriteLine(targetTime);
// Displays 5/1/2008 8:30:00 AM -07:00
Der Offset des resultierenden DateTimeOffset-Werts hängt vom Wert der DateTime.Kind-Eigenschaft ab. Wenn der Wert DateTimeKind.Utc lautet, entspricht der Offset TimeSpan.Zero. Wenn der Wert DateTimeKind.Local oder DateTimeKind.Unspecified lautet, entspricht der Offset dem der lokalen Zeitzone.
Analysieren der Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts
Der DateTimeOffset-Typ unterstützt vier Methoden zur Konvertierung der Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts in einen DateTimeOffset-Wert:
Die Parse-Methode, die versucht, die Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts in einen DateTimeOffset-Wert zu konvertieren, und eine Ausnahme auslöst, wenn die Konvertierung fehlschlägt.
Die TryParse-Methode, die versucht, die Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts in einen DateTimeOffset-Wert zu konvertieren, und false zurückgibt, wenn die Konvertierung fehlschlägt.
Die ParseExact-Methode, die versucht, die Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts in einem angegebenen Format in einen DateTimeOffset-Wert zu konvertieren. Die Methode löst eine Ausnahme aus, wenn die Konvertierung fehlschlägt.
Die TryParseExact-Methode, die versucht, die Zeichenfolgendarstellung eines Datums- und Uhrzeitwerts in einem angegebenen Format in einen DateTimeOffset-Wert zu konvertieren. Die Methode gibt false zurück, wenn die Konvertierung fehlschlägt.
Das folgende Beispiel zeigt Aufrufe dieser vier Konvertierungsmethoden zum Instanziieren eines DateTimeOffset-Werts.
Dim timeString As String
Dim targetTime As DateTimeOffset
timeString = "05/01/2008 8:30 AM +01:00"
Try
targetTime = DateTimeOffset.Parse(timeString)
Console.WriteLine(targetTime)
Catch e As FormatException
Console.WriteLine("Unable to parse {0}.", timeString)
End Try
timeString = "05/01/2008 8:30 AM"
If DateTimeOffset.TryParse(timeString, targetTime) Then
Console.WriteLine(targetTime)
Else
Console.WriteLine("Unable to parse {0}.", timeString)
End If
timeString = "Thursday, 01 May 2008 08:30"
Try
targetTime = DateTimeOffset.ParseExact(timeString, "f", _
CultureInfo.InvariantCulture)
Console.WriteLine(targetTime)
Catch e As FormatException
Console.WriteLine("Unable to parse {0}.", timeString)
End Try
timeString = "Thursday, 01 May 2008 08:30 +02:00"
Dim formatString As String
formatString = CultureInfo.InvariantCulture.DateTimeFormat.LongDatePattern & _
" " & _
CultureInfo.InvariantCulture.DateTimeFormat.ShortTimePattern & _
" zzz"
If DateTimeOffset.TryParseExact(timeString, _
formatString, _
CultureInfo.InvariantCulture, _
DateTimeStyles.AllowLeadingWhite, _
targetTime) Then
Console.WriteLine(targetTime)
Else
Console.WriteLine("Unable to parse {0}.", timeString)
End If
' The example displays the following output to the console:
' 5/1/2008 8:30:00 AM +01:00
' 5/1/2008 8:30:00 AM -07:00
' 5/1/2008 8:30:00 AM -07:00
' 5/1/2008 8:30:00 AM +02:00
string timeString;
DateTimeOffset targetTime;
timeString = "05/01/2008 8:30 AM +01:00";
try
{
targetTime = DateTimeOffset.Parse(timeString);
Console.WriteLine(targetTime);
}
catch (FormatException)
{
Console.WriteLine("Unable to parse {0}.", timeString);
}
timeString = "05/01/2008 8:30 AM";
if (DateTimeOffset.TryParse(timeString, out targetTime))
Console.WriteLine(targetTime);
else
Console.WriteLine("Unable to parse {0}.", timeString);
timeString = "Thursday, 01 May 2008 08:30";
try
{
targetTime = DateTimeOffset.ParseExact(timeString, "f",
CultureInfo.InvariantCulture);
Console.WriteLine(targetTime);
}
catch (FormatException)
{
Console.WriteLine("Unable to parse {0}.", timeString);
}
timeString = "Thursday, 01 May 2008 08:30 +02:00";
string formatString;
formatString = CultureInfo.InvariantCulture.DateTimeFormat.LongDatePattern +
" " +
CultureInfo.InvariantCulture.DateTimeFormat.ShortTimePattern +
" zzz";
if (DateTimeOffset.TryParseExact(timeString,
formatString,
CultureInfo.InvariantCulture,
DateTimeStyles.AllowLeadingWhite,
out targetTime))
Console.WriteLine(targetTime);
else
Console.WriteLine("Unable to parse {0}.", timeString);
// The example displays the following output to the console:
// 5/1/2008 8:30:00 AM +01:00
// 5/1/2008 8:30:00 AM -07:00
// 5/1/2008 8:30:00 AM -07:00
// 5/1/2008 8:30:00 AM +02:00