3 回答
TA贡献1856条经验 获得超11个赞
您将无法从中获取价格TimeSpan,因为“月”是可变的计量单位。您必须自己计算它,并且必须弄清楚您希望它如何工作。
例如,要日期喜欢July 5, 2009并August 4, 2009产生一个月或零月区别?如果你说这应该产生一个,然后怎么样July 31, 2009和August 1, 2009?是那一个月?它仅仅是Month日期值的差异,还是与实际时间跨度更相关?确定所有这些规则的逻辑很重要,因此您必须确定自己的规则并实施适当的算法。
如果您想要的只是月份中的不同(完全不考虑日期值),则可以使用以下方法:
public static int MonthDifference(this DateTime lValue, DateTime rValue)
{
return (lValue.Month - rValue.Month) + 12 * (lValue.Year - rValue.Year);
}
请注意,这将返回一个相对差,这意味着如果rValue大于lValue,则返回值将为负。如果需要绝对差异,可以使用以下方法:
public static int MonthDifference(this DateTime lValue, DateTime rValue)
{
return Math.Abs((lValue.Month - rValue.Month) + 12 * (lValue.Year - rValue.Year));
}
TA贡献1825条经验 获得超4个赞
这是比较痛苦的纯.NET做。我建议我自己的Noda Time库,该库是专门为以下目的而设计的:
LocalDate start = new LocalDate(2009, 10, 6);
LocalDate end = new LocalDate(2009, 12, 25);
Period period = Period.Between(start, end);
int months = period.Months;
(还有其他选择,例如,即使您只想数月甚至数年,也可以使用Period period = Period.Between(start, end, PeriodUnits.Months);)
TA贡献1833条经验 获得超4个赞
也许您不想知道月份分数;这段代码呢?
public static class DateTimeExtensions
{
public static int TotalMonths(this DateTime start, DateTime end)
{
return (start.Year * 12 + start.Month) - (end.Year * 12 + end.Month);
}
}
// Console.WriteLine(
// DateTime.Now.TotalMonths(
// DateTime.Now.AddMonths(-1))); // prints "1"
- 3 回答
- 0 关注
- 793 浏览
添加回答
举报