У меня есть странная проблема с округлением даты, которую, надеюсь, кто-то сможет решить. Мой клиент использует рабочую неделю с понедельника по воскресенье. Дата воскресенья считается концом недели и используется для идентификации всех записей, введенных за определенную неделю (так что все, что было введено на прошлой неделе, будет иметь значение WEEKDATE «26.10.2008», что является датой воскресенья).
Одна маленькая особенность заключается в том, что пользователи вводят записи за предыдущую неделю до 11 часов утра понедельника текущей недели.
Поэтому мне нужна функция, которая начинается с DateTime.Now и возвращает дату окончания недели (без временной части) в соответствии с приведенными выше правилами. Спасибо за вашу помощь. У меня есть работающее решение, но я слишком стесняюсь его публиковать.
О, и я не могу использовать LINQ.





public DateTime WeekNum(DateTime now)
{
DateTime NewNow = now.AddHours(-11).AddDays(6);
return (NewNow.AddDays(- (int) NewNow.DayOfWeek).Date);
}
public void Code(params string[] args)
{
Console.WriteLine(WeekNum(DateTime.Now));
Console.WriteLine(WeekNum(new DateTime(2008,10,27, 10, 00, 00)));
Console.WriteLine(WeekNum(new DateTime(2008,10,27, 12, 00, 00)));
Console.WriteLine(WeekNum(new DateTime(2008,10,28)));
Console.WriteLine(WeekNum(new DateTime(2008,10,25)));
}
Вы можете жестко запрограммировать DateTime.Now вместо передачи объекта DateTime. Это просто упростило тестирование.
@ Джоэл: Извините, опубликовал слишком быстро. Исправленная версия должна работать.
Спасибо, Джеймс. Я добавил .Date в строку возврата, поэтому я получаю только дату.
Это проходит и для меня:
[Test]
public void Test()
{
DateTime sunday = DateTime.Parse("10/26/2008");
DateTime nextSunday = DateTime.Parse("11/2/2008");
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/21/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/22/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/23/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/24/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/25/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/26/2008")));
Assert.AreEqual(sunday, GetSunday(DateTime.Parse("10/27/2008 10:59 AM")));
Assert.AreEqual(nextSunday, GetSunday(DateTime.Parse("10/27/2008 11:00 AM")));
}
private DateTime GetSunday(DateTime date)
{
if (date.DayOfWeek == DayOfWeek.Monday && date.Hour < 11)
return date.Date.AddDays(-1);
while (date.DayOfWeek != DayOfWeek.Sunday)
date = date.AddDays(1);
return date.Date;
}
Я успешно использовал эти расширения:
DateTime GetMidnightFollowingSunday()
{
DateTime now = DateTime.Now;
return now.AddDays(7 - (int)now.DayOfWeek).Date;
}
Если вам нужно начать новую неделю после 11 часов утра понедельника, просто вычтите 11 часов с этого момента, но тогда, вероятно, имеет смысл назвать метод как-нибудь иначе.
DateTime GetRecordDate()
{
DateTime nowMinusOffset = DateTime.Now.AddHours(-11);
return nowMinusOffset.AddDays(7-(int)nowMinusOffset.DayOfWeek).Date;
}
Близко, но вы превращаете текущее воскресенье в следующее воскресенье.
DayOfWeek - это воскресенье = 0, понедельник = 1 и т. д.?