这不是.TotalDays作为小于24小时的时段可能仍然通过重叠两个不同的日期返回“2”.同样,相隔两分钟的日期仍应返回“1”.
例如:
2012-2-1 14:00 to 2012-2-2 23:00 -> 2 (1st and 2nd Feb)2012-2-1 14:00 to 2012-2-2 10:00 -> 2 (1st and 2nd Feb)2012-2-1 23:00 to 2012-2-2 00:00 -> 2 (1st and 2nd Feb)2012-2-1 23:00 to 2012-2-3 00:00 -> 3 (1st,2nd,3rd Feb)2012-2-1 14:00 to 2012-2-1 15:00 -> 1 (1st Feb)2012-2-1 14:00 to 2012-2-1 14:00 -> 1 (1st Feb)2012-1-1 00:00 to 2012-12-31 23:59 -> 366 (All of 2012)
我可以使用以下代码获得此功能:
DateTime dt1 = new DateTime(2000,1,2,12,00,00);DateTime dt2 = new DateTime(2000,3,03,00);int count = 0;for (DateTime date = dt1; date.Date <= dt2.Date; date = date.AddDays(1)) count++;return count;
有没有更好的办法?
解决方法 为什么不呢:int count = dt1.Date.Subtract(dt2.Date).Duration().Days + 1;
使用.Date将日期规范化为午夜(0:00),将天数加1以获取不同日期的数量,而不仅仅是两者之间的天数.
使用持续时间可确保您始终获得肯定答案.
总结以上是内存溢出为你收集整理的c# – 计算日期所涵盖的包含日期数全部内容,希望文章能够帮你解决c# – 计算日期所涵盖的包含日期数所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)