| using System; | 
 | using System.Collections.Generic; | 
 | using System.Linq; | 
 | using System.Text; | 
 | using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime.Workdays; | 
 | using OfficeOpenXml.FormulaParsing.ExpressionGraph; | 
 |  | 
 | namespace OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime | 
 | { | 
 |     public class Networkdays : ExcelFunction | 
 |     { | 
 |         public override CompileResult Execute(IEnumerable<FunctionArgument> arguments, ParsingContext context) | 
 |         { | 
 |             var functionArguments = arguments as FunctionArgument[] ?? arguments.ToArray(); | 
 |             ValidateArguments(functionArguments, 2); | 
 |             var startDate = System.DateTime.FromOADate(ArgToInt(functionArguments, 0)); | 
 |             var endDate = System.DateTime.FromOADate(ArgToInt(functionArguments, 1)); | 
 |             var calculator = new WorkdayCalculator(); | 
 |             var result = calculator.CalculateNumberOfWorkdays(startDate, endDate); | 
 |             if (functionArguments.Length > 2) | 
 |             { | 
 |                 result = calculator.ReduceWorkdaysWithHolidays(result, functionArguments[2]); | 
 |             } | 
 |              | 
 |             return new CompileResult(result.NumberOfWorkdays, DataType.Integer); | 
 |         } | 
 |     } | 
 | } |