| using System; |
| using System.Collections.Generic; |
| using System.Linq; |
| using System.Text; |
| using OfficeOpenXml.FormulaParsing.Exceptions; |
| using OfficeOpenXml.FormulaParsing.ExpressionGraph; |
| using OfficeOpenXml.Utils; |
| |
| namespace OfficeOpenXml.FormulaParsing.Excel.Functions.Information |
| { |
| public class N : ExcelFunction |
| { |
| public override CompileResult Execute(IEnumerable<FunctionArgument> arguments, ParsingContext context) |
| { |
| ValidateArguments(arguments, 1); |
| var arg = GetFirstValue(arguments); |
| |
| if (arg is bool) |
| { |
| var val = (bool) arg ? 1d : 0d; |
| return CreateResult(val, DataType.Decimal); |
| } |
| else if (IsNumeric(arg)) |
| { |
| var val = ConvertUtil.GetValueDouble(arg); |
| return CreateResult(val, DataType.Decimal); |
| } |
| else if (arg is string) |
| { |
| return CreateResult(0d, DataType.Decimal); |
| } |
| else if (arg is ExcelErrorValue) |
| { |
| return CreateResult(arg, DataType.ExcelError); |
| } |
| throw new ExcelErrorValueException(eErrorType.Value); |
| } |
| } |
| } |