首页 > 解决方案 > c#Web应用程序如何获取不包括周末和公共假期的工作日

问题描述

背景资料

刚开始学习 C#,我正在尝试构建一个简单的 Web 应用程序来计算两个日期之间的工作日数。

The UI of the web app

在此处输入图像描述

基本逻辑是当用户输入一个日期(即01/05/2018)并点击按钮时,它会计算工作日的总数(不包括周末和公共假期)。

现在的问题是计算不准确,即在 23/05/2018 和 31/05/2018 之间显示 6,应该是 7 天。并且在计算过程中不考虑日期

namespace testtest
{
public partial class First : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
    }


    //on btn click
    protected void Button1_Click(object sender, EventArgs e)
    {


        string dt = TextBox1.Text;
        DateTime dtDDMMYYYY = ParseDate(dt);


        string dt2 = TextBox2.Text;
        DateTime dtDDMMYYYY2 = ParseDate(dt2);

       List<DateTime> list = new List<DateTime> { 
        DateTime.ParseExact("04/05/2018", "dd/MM/yyyy", 
       CultureInfo.InvariantCulture) };

        DaysLeft(dtDDMMYYYY, dtDDMMYYYY2, true, list);
    }


    public DateTime ParseDate(string date)
    {
        DateTimeFormatInfo dateFormatProvider = new DateTimeFormatInfo();
        dateFormatProvider.ShortDatePattern = "dd/MM/yyyy";
        return DateTime.Parse(date, dateFormatProvider);
    }



    public int DaysLeft(DateTime startDate, DateTime endDate, Boolean 
     excludeWeekends, List<DateTime> excludeDates)
    {


        int count = 0;
        for (DateTime index = startDate; index < endDate; index = 
        index.AddDays(1))
        {
            if (excludeWeekends && index.DayOfWeek != DayOfWeek.Sunday && 
           index.DayOfWeek != DayOfWeek.Saturday)
            {
                bool excluded = false; ;
                for (int i = 0; i < excludeDates.Count; i++)
                {
                    if (index.Date.CompareTo(excludeDates[i].Date) == 0)
                    {
                        excluded = true;
                        break;
                    }
                }

                if (!excluded)
                {
                    count++;
                }
            }
        }
        result.Text = count.ToString();
        return count;
    }


}

}

标签: c#asp.net

解决方案


把事情简单化

public int DaysLeft(DateTime startDate, DateTime endDate, Boolean excludeWeekends, List<DateTime> excludeDates) {
    int count = 0;
    for (DateTime index = startDate; index <= endDate; index = index.AddDays(1)) {
        if (excludeWeekends && (index.DayOfWeek == DayOfWeek.Sunday || index.DayOfWeek == DayOfWeek.Saturday))
            continue;

        if (excludeDates.Contains(index.Date))
            continue;

        count++;
    }
    return count;
}

如果日期是周末并被excludeWeekends标记,则继续到下一个日期,如果日期包含在excludeDates继续中,则计算当天。


推荐阅读