所以我试图将以下格式的字符串日期转换为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);
Jon Skeet.. 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中你不需要这样做,因为它支持纳秒的精度:)
我不相信你可以使用正常的解析代码和现有的文本来做到这一点.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中你不需要这样做,因为它支持纳秒的精度:)
添加Jon的答案7
是解析的限制并表示秒分数的有效数字.
从该"fffffff"
自定义格式说明
虽然可以显示时间值的第二个组成部分的百万分之一,但该值可能没有意义.日期和时间值的精度取决于系统时钟的分辨率.在Windows NT 3.5(及更高版本)和Windows Vista操作系统上,时钟的分辨率大约为10-15毫秒.