Практическое руководство. Отображение миллисекунд в значениях даты и времени

Стандартные методы форматирования даты и времени, например DateTime.ToString(), поддерживают часы, минуты и секунды, но не миллисекунды. В этой статье показано, как включить компонент даты и времени в форматированные строки даты и времени.

Отображение компонента миллисекунд для значения DateTime

  1. Если вы работаете со строковым представлением даты, преобразуйте его в DateTime значение или DateTimeOffset значение с помощью статического DateTime.Parse(String) или DateTimeOffset.Parse(String) метода.

  2. Чтобы извлечь строковое представление компонента миллисекунда времени, вызовите значение DateTime.ToString(String) даты и времени или ToString метод, а также передайте fffFFF шаблон или шаблон пользовательского формата отдельно или с другими пользовательскими описателями формата в качестве format параметра.

Совет

Свойство System.Globalization.NumberFormatInfo.NumberDecimalSeparator задает разделитель миллисекунда.

Пример

В примере отображается компонент миллисекунда и DateTimeDateTimeOffset значения в консоли, один и включенный в длинную строку даты и времени.

using System.Globalization;
using System.Text.RegularExpressions;

string dateString = "7/16/2008 8:32:45.126 AM";

try
{
    DateTime dateValue = DateTime.Parse(dateString);
    DateTimeOffset dateOffsetValue = DateTimeOffset.Parse(dateString);

    // Display Millisecond component alone.
    Console.WriteLine("Millisecond component only: {0}",
                    dateValue.ToString("fff"));
    Console.WriteLine("Millisecond component only: {0}",
                    dateOffsetValue.ToString("fff"));

    // Display Millisecond component with full date and time.
    Console.WriteLine("Date and Time with Milliseconds: {0}",
                    dateValue.ToString("MM/dd/yyyy hh:mm:ss.fff tt"));
    Console.WriteLine("Date and Time with Milliseconds: {0}",
                    dateOffsetValue.ToString("MM/dd/yyyy hh:mm:ss.fff tt"));

    string fullPattern = DateTimeFormatInfo.CurrentInfo.FullDateTimePattern;
    
    // Create a format similar to .fff but based on the current culture.
    string millisecondFormat = $"{NumberFormatInfo.CurrentInfo.NumberDecimalSeparator}fff";

    // Append millisecond pattern to current culture's full date time pattern.
    fullPattern = Regex.Replace(fullPattern, "(:ss|:s)", $"$1{millisecondFormat}");

    // Display Millisecond component with modified full date and time pattern.
    Console.WriteLine("Modified full date time pattern: {0}",
                    dateValue.ToString(fullPattern));
    Console.WriteLine("Modified full date time pattern: {0}",
                    dateOffsetValue.ToString(fullPattern));
}
catch (FormatException)
{
    Console.WriteLine("Unable to convert {0} to a date.", dateString);
}
// The example displays the following output if the current culture is en-US:
//    Millisecond component only: 126
//    Millisecond component only: 126
//    Date and Time with Milliseconds: 07/16/2008 08:32:45.126 AM
//    Date and Time with Milliseconds: 07/16/2008 08:32:45.126 AM
//    Modified full date time pattern: Wednesday, July 16, 2008 8:32:45.126 AM
//    Modified full date time pattern: Wednesday, July 16, 2008 8:32:45.126 AM
Imports System.Globalization
Imports System.Text.REgularExpressions

Module MillisecondDisplay
    Public Sub Main()

        Dim dateString As String = "7/16/2008 8:32:45.126 AM"

        Try
            Dim dateValue As Date = Date.Parse(dateString)
            Dim dateOffsetValue As DateTimeOffset = DateTimeOffset.Parse(dateString)

            ' Display Millisecond component alone.
            Console.WriteLine("Millisecond component only: {0}", _
                              dateValue.ToString("fff"))
            Console.WriteLine("Millisecond component only: {0}", _
                              dateOffsetValue.ToString("fff"))

            ' Display Millisecond component with full date and time.
            Console.WriteLine("Date and Time with Milliseconds: {0}", _
                              dateValue.ToString("MM/dd/yyyy hh:mm:ss.fff tt"))
            Console.WriteLine("Date and Time with Milliseconds: {0}", _
                              dateOffsetValue.ToString("MM/dd/yyyy hh:mm:ss.fff tt"))

            Dim fullPattern As String = DateTimeFormatInfo.CurrentInfo.FullDateTimePattern

            ' Create a format similar to .fff but based on the current culture.
            Dim millisecondFormat as String = $"{NumberFormatInfo.CurrentInfo.NumberDecimalSeparator}fff"
            
            ' Append millisecond pattern to current culture's full date time pattern.
            fullPattern = Regex.Replace(fullPattern, "(:ss|:s)", $"$1{millisecondFormat}")

            ' Display Millisecond component with modified full date and time pattern.
            Console.WriteLine("Modified full date time pattern: {0}", _
                              dateValue.ToString(fullPattern))
            Console.WriteLine("Modified full date time pattern: {0}", _
                              dateOffsetValue.ToString(fullPattern))
        Catch e As FormatException
            Console.WriteLine("Unable to convert {0} to a date.", dateString)
        End Try
    End Sub
End Module
' The example displays the following output if the current culture is en-US:
'    Millisecond component only: 126
'    Millisecond component only: 126
'    Date and Time with Milliseconds: 07/16/2008 08:32:45.126 AM
'    Date and Time with Milliseconds: 07/16/2008 08:32:45.126 AM
'    Modified full date time pattern: Wednesday, July 16, 2008 8:32:45.126 AM
'    Modified full date time pattern: Wednesday, July 16, 2008 8:32:45.126 AM

Шаблон формата fff содержит конечные нули в значении миллисекунд. Шаблон формата FFF запрещает их. В следующем примере показано различие.

DateTime dateValue = new DateTime(2008, 7, 16, 8, 32, 45, 180);
Console.WriteLine(dateValue.ToString("fff"));
Console.WriteLine(dateValue.ToString("FFF"));
// The example displays the following output to the console:
//    180
//    18
Dim dateValue As New Date(2008, 7, 16, 8, 32, 45, 180)
Console.WriteLIne(dateValue.ToString("fff"))
Console.WriteLine(dateValue.ToString("FFF"))
' The example displays the following output to the console:
'    180
'    18

Проблема с определением полного пользовательского описателя формата, включающего компонент миллисекунда даты и времени, заключается в том, что он определяет жестко закодированный формат, который может не соответствовать расположению элементов времени в текущем языке и региональных параметрах приложения. Вместо этого лучше всего извлечь один из шаблонов отображения даты и времени, определенных текущим объектом языка и региональных параметров DateTimeFormatInfo, а затем изменить его для поддержки миллисекунд. Этот подход также показан в примере. Он извлекает полный шаблон даты и времени текущего языка и региональных параметров из DateTimeFormatInfo.FullDateTimePattern свойства, а затем вставляет пользовательский шаблон fff вместе с миллисекундным разделителем текущего языка и региональных параметров. В примере используется регулярное выражение для выполнения этой операции в одном вызове метода.

Описатель настраиваемого формата также используется для отображения дробной части секунд, отличной от миллисекунд. Например, fF описатель или настраиваемый описатель формата отображает десятые доли секунды, FFff а описатель пользовательского формата отображает соты секунды, а ffff описатель FFFF или настраиваемый формат отображает десять тысяч секунд. Дробные части миллисекунд усекаются, а не округляются в возвращаемой строке. Эти описатели формата используются в следующем примере:

DateTime dateValue = new DateTime(2008, 7, 16, 8, 32, 45, 180);
Console.WriteLine("{0} seconds", dateValue.ToString("s.f"));
Console.WriteLine("{0} seconds", dateValue.ToString("s.ff"));
Console.WriteLine("{0} seconds", dateValue.ToString("s.ffff"));
// The example displays the following output to the console:
//    45.1 seconds
//    45.18 seconds
//    45.1800 seconds
Dim dateValue As New DateTime(2008, 7, 16, 8, 32, 45, 180)
Console.WriteLine("{0} seconds", dateValue.ToString("s.f"))
Console.WriteLine("{0} seconds", dateValue.ToString("s.ff"))
Console.WriteLine("{0} seconds", dateValue.ToString("s.ffff"))
' The example displays the following output to the console:
'    45.1 seconds
'    45.18 seconds
'    45.1800 seconds

Примечание.

Можно отобразить очень маленькие дробные единицы секунды, такие как десять тысяч секунды или сотни тысяч секунды. Однако эти значения могут быть не значимыми. Точность значения даты и времени зависит от разрешения часов операционной системы. Дополнительные сведения см. в api, используемом операционной системой:

См. также