我在一个场景中运行,我需要找到当前时段的总小时数.我有一个时间和TimeOut日期时间,我希望得到员工在第二天晚上10点到凌晨4点之间工作的时间.我如何获得工作小时的输出.
public static decimal GetNightDifferentialValue(this DailyTime dtr,Employee201 employee,PayrollSettings settings,IEnumerable<Holidays> holidays) { //kNow if the time out is greater than 10pm of the dtr //07-26-2016 14:00 - 07-27-2016 03:00 //if time out i var days = Enumerable.Range(0,(int)(dtr.TimeOut - dtr.TimeIn).TotalHours + 1) .Select(i => dtr.TimeIn.AddHours(i)) .Where(date => !(date.Hour >= 22)).Count(); return days* employee.Rate; }
我的问题是在Where方法中如何过滤仅属于我的类别的小时数
解决方法
public static decimal GetNightDifferentialValue(this DailyTime dtr,IEnumerable<Holidays> holidays) { //kNow if the time out is greater than 10pm of the dtr //07-26-2016 14:00 - 07-27-2016 03:00 //if time out i DateTime dayIn10pm = new DateTime(dtr.TimeIn.Year,dtr.TimeIn.Month,dtr.TimeIn.Day,22,0); DateTime dayAfter04am = dayIn10pm.Add(new TimeSpan(6,0)); var hours = Enumerable.Range(0,(int)(dtr.TimeOut - dtr.TimeIn).TotalHours + 1) .Select(i => dtr.TimeIn.AddHours(i)) .Where(date => (date > dayIn10pm && date <= dayAfter04am)).Count(); return hours; }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。