使用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....