我如何才能更改日期时间对象中的年份?
我需要从excel调用一些日期,如果我调用的日期是在今天日期之前,则将年份设置为2099.
例如:被称为日期:15/11/2010需要设置为15/11/2099
这可行吗?或者最好改变整个日期?
Tim*_*ter 14
你只需要创建一个新的,DateTime因为它DateTime是一个不可变的结构:
DateTime newDt = new DateTime(2099, dt.Month, dt.Day);
Run Code Online (Sandbox Code Playgroud)
如果你想处理leapyear问题(源日期是在leapyear但目标年份没有),你可以使用以下扩展方法:
public static DateTime ChangeYear(this DateTime dt, int newYear)
{
return dt.AddYears(newYear - dt.Year);
}
Run Code Online (Sandbox Code Playgroud)
这将保留偶数Ticks和Kind,因此它比使用DateTime构造函数更好.02/28/2099 如果原始DateTime是02/29/2016(闰年),它将返回.
您可以这样使用它:
DateTime dt = new DateTime(2016, 2, 29);
DateTime newDt = dt.ChangeYear(2099);
Run Code Online (Sandbox Code Playgroud)
DateTime是不可变类型.您不能更改年份或其他任何部分.您应该DateTime使用新年创建新实例.没有其他选择.
var date1 = DateTime.Now;
var date2 = new DateTime(2099, date1.Month, date1.Day);
Run Code Online (Sandbox Code Playgroud)
如果您需要经常这样做,可以写一个扩展名:
public static DateTime JumpToYear(this DateTime date, int year)
{
// you can also provide Hour, Minute, Second and Millisecond
return new DateTime(year, date.Month, date.Day);
}
Run Code Online (Sandbox Code Playgroud)
用法:
var date2 = date1.JumpToYear(2099);
Run Code Online (Sandbox Code Playgroud)
注意:更改年份时,2月29日日期可能无效.
| 归档时间: |
|
| 查看次数: |
13214 次 |
| 最近记录: |