.NET日期比较:计算自日期以来的工作日数?
时间:2020-03-06 15:03:50 来源:igfitidea点击:
自日期以来计算工作天数的最简单方法是什么?首选VB.NET,但Cis还可以。
所谓"工作日",是指除星期六和星期日以外的所有日子。如果该算法还可以考虑一系列不应该算作工作日的特定"排除"日期,那将是很重要的。
在此先感谢我们贡献的天才。
解决方案
这是用于SQL Server的方法。页面上还有一个vbscript方法。我知道我们要求的不完全是。
最简单的方法可能是
DateTime start = new DateTime(2008, 10, 3); DateTime end = new DateTime(2008, 12, 31); int workingDays = 0; while( start < end ) { if( start.DayOfWeek != DayOfWeek.Saturday && start.DayOfWeek != DayOfWeek.Sunday ) { workingDays++; } start = start.AddDays(1); }
它可能不是最有效的,但它确实允许轻松检查假期列表。
DateDiff和其他一些Date *函数是VB.NET独有的,并且经常引起Cdevelopers的羡慕。不过,不确定在这种情况下是否会很有帮助。
我们结合了两个CodeProject文章,以得出一个完整的解决方案。我们的库不够简洁,无法发布为源代码,但是我可以为我们指出我们用来实现所需功能的两个项目。与CodeProject文章一样,请阅读注释,其中可能包含重要信息。
计算工作日:http://www.codeproject.com/KB/cs/busdatescalculation.aspx
其他工作日计算:http://www.codeproject.com/KB/cs/datetimelib.aspx
计算假期:http://www.codeproject.com/KB/dotnet/HolidayCalculator.aspx
一般而言(无代码)-
- 减去日期以获得天数
- 除以7得到周数
- 减去周数乘以2
- 计算属于该日期范围的假期日期数
- 减去那个数
弄乱开始/结束日期,使它们在星期一至星期一降落,然后加回差额
[对无代码通用性的道歉,已经太迟了]
[c.f. endDate.Subtract(startDate).TotalDays]
这会做我们想要的。转换为VB.NET应该很容易,但是我已经花了很长时间才能做到。
DateTime start = DateTime.Now; DateTime end = start.AddDays(9); IEnumerable<DateTime> holidays = new DateTime[0]; // basic data int days = (int)(end - start).TotalDays; int weeks = days / 7; // check for a weekend in a partial week from start. if (7- (days % 7) <= (int)start.DayOfWeek) days--; if (7- (days % 7) <= (int)start.DayOfWeek) days--; // lose the weekends days -= weeks * 2; foreach (DateTime dt in holidays) { if (dt > start && dt < end) days--; }