Подтвердить что ты не робот

Как перемещаться между двумя датами

У меня есть календарь, который передает выбранные даты в виде строк в метод. Внутри этого метода я хочу сгенерировать список всех дат, начиная с выбранной даты начала и заканчивая выбранной датой окончания, очевидно, включая все даты между ними, независимо от того, сколько дней находится между выбранными датами начала и окончания.

Ниже у меня есть начало метода, который берет строки даты и преобразует их в переменные DateTime, чтобы я мог использовать функции вычисления DateTime. Однако я не могу понять, как рассчитать все даты между датой начала и окончания? Очевидно, что первый этап - вычесть дату начала с даты окончания, но я не могу рассчитать остальные этапы.

Помогите оценить,

С уважением.

public void DTCalculations()
{
List<string> calculatedDates = new List<string>();
string startDate = "2009-07-27";
string endDate = "2009-07-29";

//Convert to DateTime variables
DateTime start = DateTime.Parse(startDate);
DateTime end = DateTime.Parse(endDate);

//Calculate difference between start and end date.
TimeSpan difference =  end.Subtract(start);

//Generate list of dates beginning at start date and ending at end date.
//ToDo:
}
4b9b3361

Ответ 1

static IEnumerable<DateTime> AllDatesBetween(DateTime start, DateTime end)
{
    for(var day = start.Date; day <= end; day = day.AddDays(1))
        yield return day;
}

Изменить: добавлен код для решения вашего конкретного примера и для демонстрации использования:

var calculatedDates = 
    new List<string>
    (
        AllDatesBetween
        (
            DateTime.Parse("2009-07-27"),
            DateTime.Parse("2009-07-29")
        ).Select(d => d.ToString("yyyy-MM-dd"))
    );

Ответ 2

Вам просто нужно выполнять итерацию от начала до конца, вы можете сделать это в цикле for

DateTime start = DateTime.Parse(startDate);
DateTime end = DateTime.Parse(endDate);

for(DateTime counter = start; counter <= end; counter = counter.AddDays(1))
{
    calculatedDates.Add(counter);
}

Ответ 3

Самое простое занятие - взять дату начала и добавить к нему 1 день (используя AddDays), пока не достигнете даты окончания. Что-то вроде этого:

DateTime calcDate = start.Date;
while (calcDate <= end)
{
    calcDate = calcDate.AddDays(1);
    calculatedDates.Add(calcDate.ToString());
}

Очевидно, вы отрегулировали бы условное и положение вызова AddDays в зависимости от того, хотите ли вы включать даты начала и окончания в коллекцию или нет.

[Edit: Кстати, вы должны рассмотреть возможность использования TryParse() вместо Parse(), если переданные строки не преобразуются в даты красиво]

Ответ 4

for( DateTime i = start; i <= end; i = i.AddDays( 1 ) )
{
    Console.WriteLine(i.ToShortDateString());
}

Ответ 5

Альтернативный метод

public static class MyExtensions
{
    public static IEnumerable EachDay(this DateTime start, DateTime end)
    {
        // Remove time info from start date (we only care about day). 
        DateTime currentDay = new DateTime(start.Year, start.Month, start.Day);
        while (currentDay <= end)
        {
            yield return currentDay;
            currentDay = currentDay.AddDays(1);
        }
    }
}

Теперь в вызывающем коде вы можете сделать следующее:

DateTime start = DateTime.Now;
DateTime end = start.AddDays(20);
foreach (var day in start.EachDay(end))
{
    ...
}

Другим преимуществом этого подхода является то, что он делает тривиальным добавление EveryWeek, EveryMonth и т.д. Затем они будут доступны в DateTime.