将字符串转换为DateTime,小于7的十进制小数

时间:2015-12-10 14:43:19

标签: c# datetime

所以我试图将以下格式的字符串日期转换为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);

2 个答案:

答案 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   毫秒。