所以我试图将以下格式的字符串日期转换为DateTime。我可以使用ParseExact解析它,当使用格式字符串" fffffff"有7个小数秒的小数时,但我得到的字符串可以(不总是)小数点后9位小数。
我真的不在乎最后几位数是什么,因为我最终还是会绕过它。在我从ParseExact方法得到错误之前,我正在寻找的是解析它们或截断它们的某种方法,因为它不会与" fffffff"匹配。我唯一的想法是根据小数点后面的字符数截断字符串。有更简单的方法吗?提前谢谢!
要解析的示例字符串:" 2015-12-10 13:14:15.123456789"
DateTime.ParseExact("2015-12-10 13:14:15.123456789", "yyyy-MM-dd HH:mm:ss.fffffff", System.Globalization.CultureInfo.InvariantCulture);
抛出FormatException,但以下工作。
DateTime.ParseExact("2015-12-10 13:14:15.1234567", "yyyy-MM-dd HH:mm:ss.fffffff", System.Globalization.CultureInfo.InvariantCulture);
答案 0 :(得分:9)
我不相信你可以用正常的解析代码和现有的文本来做到这一点。 DateTime
的精度仅下降到刻度线,刻度为100纳秒。我认为最简单的事情就是截断字符串本身:
string pattern = "yyyy-MM-dd HH:mm:ss.fffffff";
if (text.Length > pattern.Length)
{
text = text.Substring(0, pattern.Length);
}
DateTime value = DateTime.ParseExact(text, pattern, CultureInfo.InvariantCulture);
强制性插件:在Noda Time 2.0中你不需要这样做,因为它支持纳秒的精度:)
答案 1 :(得分:5)
要添加Jon的答案,7
是解析的限制,并代表秒分数的有效数字。
来自The "fffffff"
custom format specifier
虽然可能显示百万分之一秒 时间值的组成部分,该值可能没有意义。该 日期和时间值的精确度取决于分辨率 系统时钟。在Windows NT 3.5(及更高版本)和Windows Vista上 在操作系统中,时钟的分辨率约为10-15 毫秒。