如何以毫秒精度精确构建实际时间的时间戳?
我需要像16.4.2013 9:48:00:123这样的东西。这可能吗?我有一个应用程序,我每秒采样值10次,我需要在图表中显示它们。
答案 0 :(得分:269)
如何以毫秒精度精确构建实际时间的时间戳?
我怀疑你的意思是毫秒准确度。 DateTime
具有很高的精确度,但在准确性方面相当粗糙。一般来说,你不能。通常系统时钟(DateTime.Now
获取其数据的地方)的分辨率大约为10-15毫秒。有关详细信息,请参阅Eric Lippert的blog post about precision and accuracy。
如果您需要比此更精确的计时,您可能需要考虑使用NTP客户端。
然而,目前还不清楚你真的需要毫秒精度。如果您不关心精确时序 - 您只想以正确的顺序显示样本,并且具有“非常好”的准确度,那么系统时钟应该没问题。我建议您使用DateTime.UtcNow
而不是DateTime.Now
,以避免围绕夏令时过渡的时区问题等。
如果您的问题实际只是将DateTime
转换为精度为毫秒级的字符串,我建议使用:
string timestamp = DateTime.UtcNow.ToString("yyyy-MM-dd HH:mm:ss.fff",
CultureInfo.InvariantCulture);
(请注意,与您的样本不同,这是可排序的,并且不太可能引起混淆,无论是“月/日/年”还是“日/月/年”。)
答案 1 :(得分:104)
这应该有效:
DateTime.Now.ToString("hh.mm.ss.ffffff");
如果您不需要显示它并且只需要知道时差,那么不要将其转换为String。保留为DateTime.Now();
并使用TimeSpan
来了解时间间隔之间的差异:
实施例
DateTime start;
TimeSpan time;
start = DateTime.Now;
//Do something here
time = DateTime.Now - start;
label1.Text = String.Format("{0}.{1}", time.Seconds, time.Milliseconds.ToString().PadLeft(3, '0'));
答案 2 :(得分:22)
我正在寻找类似的解决方案,基于此线程上的建议,我使用以下内容
DateTime.Now.ToString("MM/dd/yyyy hh:mm:ss.fff")
,它像魅力一样工作。注意:.fff
是您要捕获的精确数字。
答案 3 :(得分:16)
答案 4 :(得分:13)
使用DateTime Structure,以毫秒为单位,格式如下:
string timestamp = DateTime.UtcNow.ToString("yyyy-MM-dd HH:mm:ss.fff",
CultureInfo.InvariantCulture);
timestamp = timestamp.Replace("-", ".");
答案 5 :(得分:3)
据我所知,你可以选择:
DateTime dateTime = DateTime.Now;
DateTime dateTimeInMilliseconds = dateTime.AddTicks(-1 * dateTime.Ticks % 10000);
这将切断小于1毫秒的刻度。
答案 6 :(得分:3)
如果你仍然想要一个日期而不是其他答案的字符串,只需添加这个扩展方法。
public static DateTime ToMillisecondPrecision(this DateTime d) {
return new DateTime(d.Year, d.Month, d.Day, d.Hour, d.Minute,
d.Second, d.Millisecond, d.Kind);
}
答案 7 :(得分:1)
DateTime.UtcNow
和DateTime.Now
的问题在于,根据计算机和操作系统的不同,它可能只能精确到10到15毫秒。但是,在Windows计算机上,可以使用低级函数GetSystemTimePreciseAsFileTime来获得微秒精度,请参阅下面的函数GetTimeStamp()
。
[System.Security.SuppressUnmanagedCodeSecurity, System.Runtime.InteropServices.DllImport("kernel32.dll")]
static extern void GetSystemTimePreciseAsFileTime(out FileTime pFileTime);
[System.Runtime.InteropServices.StructLayout(System.Runtime.InteropServices.LayoutKind.Sequential)]
public struct FileTime {
public const long FILETIME_TO_DATETIMETICKS = 504911232000000000; // 146097 = days in 400 year Gregorian calendar cycle. 504911232000000000 = 4 * 146097 * 86400 * 1E7
public uint TimeLow; // least significant digits
public uint TimeHigh; // most sifnificant digits
public long TimeStamp_FileTimeTicks { get { return TimeHigh * 4294967296 + TimeLow; } } // ticks since 1-Jan-1601 (1 tick = 100 nanosecs). 4294967296 = 2^32
public DateTime dateTime { get { return new DateTime(TimeStamp_FileTimeTicks + FILETIME_TO_DATETIMETICKS); } }
}
public static DateTime GetTimeStamp() {
FileTime ft; GetSystemTimePreciseAsFileTime(out ft);
return ft.dateTime;
}
答案 8 :(得分:0)
尝试使用datetime.now.ticks。这提供了纳秒级的精度。取两个刻度的增量(stoptick-starttick)/ 10,000是指定间隔的毫秒。
https://docs.microsoft.com/en-us/dotnet/api/system.datetime.ticks?view=netframework-4.7.2
答案 9 :(得分:0)
另一种选择是从源 DateTime
值构造一个新的 DateTime
实例:
// current date and time
var now = DateTime.Now;
// modified date and time with millisecond accuracy
var msec = new DateTime(now.Year, now.Month, now.Day, now.Hour, now.Minute, now.Second, now.Millisecond, now.Kind);
不需要做任何到字符串和从字符串的转换,而且它也是非常易于理解和可读的代码。
答案 10 :(得分:-2)
public long millis() {
return (long.MaxValue + DateTime.Now.ToBinary()) / 10000;
}
If you want microseconds, just change 10000
to 10
, and if you want the 10th of micro, delete / 10000
.
答案 11 :(得分:-3)
DateTime.Now.ToString( “ddMMyyyyhhmmssffff”)