В C # я пытаюсь показать количество дней между 2 выборами даты и времени, включая выбранные дни, но это не добавляет 1 день, если я выбираю сегодняшнюю дату - PullRequest
1 голос
/ 04 октября 2019

Если я начну с сегодняшнего дня и рассчитываю на 5 дней, он отображает 4 дня. Если я перенесу дату начала назад на 1, она отобразит 6
Вот то, что у меня сейчас есть и работает, если я не использую сегодняшнюю дату в качестве даты начала.

private void DaysToShow() 
{
    //Find the difference in the days selected in the drop down menu so we can calculate
    DateTime dtDateOnQuay = dtpDateOnQuay.Value;
    DateTime dtDateLeft = dtpDateLeft.Value;
    TimeSpan difference = dtDateLeft - dtDateOnQuay;

    //As the days are inclusive and the above gets the days in between, add 1
    m_iDaysRent = difference.Days + 1;
    m_iDaysDetention = m_iDaysRent;

    if (dtpDateReturned.Checked)
    {
        TimeSpan oDetentionDiff = dtpDateReturned.Value - dtpDateOnQuay.Value;
        m_iDaysDetention = oDetentionDiff.Days + 1;
    }

    txtDaysOnQuay.Text = m_iDaysRent.ToString();
    txtDaysDetention.Text = m_iDaysDetention.ToString();
}

Ответы [ 2 ]

0 голосов
/ 04 октября 2019

Изменен математический оператор и преобразован в int, как показано ниже, и теперь работает

    private void DaysToShow() 
        {
        //Find the difference in the days selected in the drop down menu so we can         calculate
        DateTime dtDateOnQuay = dtpDateOnQuay.Value;
        DateTime dtDateLeft = dtpDateLeft.Value; 
        TimeSpan difference = dtDateLeft.Subtract(dtDateOnQuay);

        //As the days are inclusive and the above gets the days in between, add 1
        m_iDaysRent = Convert.ToInt32(difference.TotalDays) +1;  
        m_iDaysDetention = m_iDaysRent;

        if (dtpDateReturned.Checked)
        {
            TimeSpan oDetentionDiff = dtpDateReturned.Value - dtpDateOnQuay.Value;
            m_iDaysDetention = oDetentionDiff.Days + 1;
        }

        txtDaysOnQuay.Text = m_iDaysRent.ToString();
        txtDaysDetention.Text = m_iDaysDetention.ToString();
    }
0 голосов
/ 04 октября 2019

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

Проверьте DaysToShowByDateComp, которая игнорирует время.

public class Program
{
    public static void Main()
    {
        DateTime endDate = DateTime.Parse("2019-10-01 23:59:59");
        DateTime startDate2 = DateTime.Parse("2019-10-04 00:00:00");
        DateTime endDate2 = DateTime.Parse("2019-10-01 00:00:00");

        Console.WriteLine(DateTime.Now.ToString());
        Console.WriteLine(endDate.ToString());

        Console.WriteLine("With today timespan:" + DaysToShowByTimeComp(DateTime.Now, endDate));        
        Console.WriteLine("With today date comparison:" + DaysToShowByDateComp(DateTime.Now, endDate));

        Console.WriteLine("With other timespan:" + DaysToShowByTimeComp(startDate2, endDate2));     
        Console.WriteLine("With other date comparison:" + DaysToShowByDateComp(startDate2, endDate2));
    }

    private static int DaysToShowByTimeComp(DateTime start, DateTime end) 
    {
        //Find the difference in the days selected in the drop down menu so we can calculate
        DateTime dtDateOnQuay = end;
        DateTime dtDateLeft = start;
        TimeSpan difference = dtDateLeft - dtDateOnQuay;

        //As the days are inclusive and the above gets the days in between, add 1
        return difference.Days + 1;
    }

    private static int DaysToShowByDateComp(DateTime start, DateTime end) 
    {
        return (int)((start.Date - end.Date).TotalDays) + 1;
    }
}

Вывод будет

10/4/2019 2:18:23 PM 
10/1/2019 11:59:59 PM 
With today timespan: 3 
With today date comparison: 4 
With other timespan: 4
With other date comparison: 4
...