使用NodaTime计算包含天数

例如,如果我有以下代码:

var nodaStart = new LocalDate(2012, 5, 1); var nodaEnd = new LocalDate(2012,5,2); var daysBetween = Period.Between(nodaStart, nodaEnd,PeriodUnits.Day); 

然后daysBetween.Days == 1

但是,我计算的范围需要计算为2天。 即它需要包括开始和结束日期。

实际的方法可以采取开始和结束日期(相隔不超过一年),并需要计算天数。 如果超过31天,则剩余的数量将返回整周。

我有那种逻辑工作正常,但因为计数是独家我有一天出去了。

我想我可以在创建nodaStart之前做startDate.addDays(-1) ,但我想知道是否有更优雅/漂亮的方式让noda返回Period。

谢谢


更新:我已经阅读了Period类的源代码 ,并且+运算符被重载,所以我可以添加

 daysBetween += Period.FromDays(1); 

(对不起,我花了很长时间才回答这个问题 – 我之前没见过。)

任何

  • 在计算之前将一天添加到最后(这是最合乎逻辑的方法,IMO – 正如Roger所说,你希望第二天开始,有效)
  • 在计算之前从开始减去一天
  • 将1加到你没有结束的天数

应该没事。 我认为Noda Time不会改变这一点。 Between是一种减法运算符的“模糊周围单位”版本 – 你不会发现许多减法运算符,其中2 – 1是2。

对于“模糊”的脑子,我们可能会考虑一段时间来包含开始日期和结束日期,如果它标识一天,一周,一个月等(参见整数倍),那么你可以编码:

 var start = new NodaTime.LocalDateTime(s.Year, s.Month, s.Day, s.Hour, s.Minute); var end = new NodaTime.LocalDateTime(e.Year, e.Month, e.Day, e.Hour, e.Minute); NodaTime.Period periodInclusive = NodaTime.Period.Between(start, end.PlusDays(1), NodaTime.PeriodUnits.AllDateUnits); NodaTime.Period period = NodaTime.Period.Between(start, end, NodaTime.PeriodUnits.AllDateUnits); bool isInclusivePeriod = periodInclusive.Days + periodInclusive.Weeks + periodInclusive.Months + periodInclusive.Years < period.Days + period.Weeks + period.Months + period.Years; period = isInclusivePeriod ? periodInclusive : period; // do stuff with period here....