获取两个日期之间的工作日时间?

时间:2013-06-12 07:36:41

标签: c# date-range

我如何得到两个日期之间的工作日小时数? (有很多工作日计算,但平日时间似乎不多 - 不是商业/开放时间,只是非周末的小时数。)

这是我的努力 - 有更好的方法吗?

void Main()
{
    // Works
    DateTime start = new DateTime(2013,6,15,0,0,0); // Saturday
    DateTime end = new DateTime(2013,6,17,10,0,0);  // Monday   

    // Result = 10 (OK)
    GetBusinessHours(start, end).Dump();        

    // Bugs
    start = new DateTime(2013,6,14,0,0,0); // Friday
    end = new DateTime(2013,6,15,0,0,0); // Saturday

    // Result = 0 (Bug) - should be 24
    GetBusinessHours(start, end).Dump();        
}

public double GetBusinessHours(DateTime start, DateTime end)
{
    double result = (end - start).TotalHours;

    int weekendDays = Enumerable.Range(0, 1 + end.Subtract(start).Days).Select(offset => start.AddDays(offset)).Count(d => d.DayOfWeek == DayOfWeek.Sunday || d.DayOfWeek == DayOfWeek.Saturday);       

    double weekendDeltaHours = 0;
    if (start.DayOfWeek == DayOfWeek.Saturday ||
        start.DayOfWeek == DayOfWeek.Sunday)
    {           
        weekendDays--;
        weekendDeltaHours = start.Date.AddDays(1).Subtract(start).TotalHours;
    }
    else if (end.DayOfWeek == DayOfWeek.Saturday ||
            end.DayOfWeek == DayOfWeek.Sunday)
    {
        weekendDeltaHours = (end - end.Date).TotalHours;
    }

    result = result - (weekendDays * 24) - weekendDeltaHours;           
    return result;
}

(对于Enumerable.Range技巧,道具为Ani。)

1 个答案:

答案 0 :(得分:2)

这不是最有效的方法,它可以满足您的需求。

var end = DateTime.Now;
var start = end.AddDays(-100);
var weekend = new[] { DayOfWeek.Saturday, DayOfWeek.Sunday };

var count = Enumerable.Range(0, Convert.ToInt32(end.Subtract(start).TotalHours))
     .Count(offset => !weekend.Contains(start.AddHours(offset).DayOfWeek));

可能值得检查int的小时数不是太大。然而,这将意味着日期范围> 245,000年!

相关问题