2014-06-24 34 views
2

我有一个名单的日期来显示它在网格中,我想添加一个小时RANGE2名单的日期,addHours列出LINQ

private void grid_loaded(object sender, RoutedEventArgs e) 
{ 
    var data = new List<EntityViewModel> 
    { 
     new EntityViewModel { aDay = new DateTime(1980, 1, 1, 12, 0, 12) }, 
     new EntityViewModel { aDay = new DateTime(1983, 1, 1, 12, 23, 12) }, 
     new EntityViewModel { aDay = new DateTime(1985, 6, 14, 12, 0, 12) }, 
     new EntityViewModel { aDay = new DateTime(1990, 7, 3, 12, 23, 12) }, 
     new EntityViewModel { aDay = new DateTime(1995, 8, 1, 4, 23, 12) }, 
     new EntityViewModel { aDay = new DateTime(1996, 1, 1, 12, 0, 12) }, 
     new EntityViewModel { aDay = new DateTime(2000, 1, 1, 12, 0, 12) }, 
     new EntityViewModel { aDay = DateTime.Now } 
    }; 

    var range = data.Where(i => i.aDay.Year >= 1983 && i.aDay.Year <= 1996).ToList(); 
    var range2 = range.Where(i => i.aDay.Date.IsDaylightSavingTime() == true).ToList(); 
} 

我尝试这样:

var range3 = range.Where(i => i.aDay.Date.IsDaylightSavingTime() == true).ToList(); 
range3.ForEach(i => i.aDay.AddHours(1)); 

这样的:

foreach (var item in range2.Where(x => x.aDay != null)) 
{ 
    item.aDay.AddHours(1); 
} 

这:

var range5 = range2.Where(i => i.aDay != null).Select(i => { i.aDay.AddHours(1); return i; }).ToList(); 

但它不会做任何事情,总是相同小时。

+1

鉴于你的代码,我想说的是增加一个小时夏令是错误的路要走,看看'ToUniversalTime()'代替,看看它是否你想要做什么。如果没有,请查看'DateTimeOffset',通常'DateTime'不是用来处理偏移量的。 IsDaylightSavingTime()的作用:指示此DateTime实例是否在当前时区的夏令时范围内。 IE浏览器,即使你添加一小时,它仍然会声明是夏令时。 – flindeberg

回答

4

AddHours不会改变最初的日期,但返回一个新的。
您需要选择这些日期:

var range5 = range2.Where(i => i.aDay != null).Select(i => i.aDay.AddHours(1)); 

要得到改变日期或

range3.ForEach(i => i.aDay = i.aDay.AddHours(1)); 

要改变列表中的项目的日期。

+0

如果我想要带走价值? – user1911

+1

如果你想减去一小时:'i.aDay.AddHours(-1)' – ChrFin

3

DateTime是一个结构,所以你要做的: var date = DateTime.Now; date = date.AddHours(1);

你的情况: range3.ForEach(i => i.aDay = i.aDay.AddHours(1));