| using OfficeOpenXml.FormulaParsing.Excel.Functions.Logical; |
| using OfficeOpenXml.FormulaParsing.ExpressionGraph; |
| using System; |
| using System.Collections.Generic; |
| using System.Linq; |
| using System.Text; |
| |
| namespace OfficeOpenXml.FormulaParsing.Excel.Functions.Math |
| { |
| public class CountBlank : ExcelFunction |
| { |
| public override CompileResult Execute(IEnumerable<FunctionArgument> arguments, ParsingContext context) |
| { |
| ValidateArguments(arguments, 1); |
| var arg = arguments.First(); |
| if(!arg.IsExcelRange)throw new InvalidOperationException("CountBlank only support ranges as arguments"); |
| var result = arg.ValueAsRangeInfo.GetNCells(); |
| foreach (var cell in arg.ValueAsRangeInfo) |
| { |
| if (!(cell.Value == null || cell.Value == string.Empty)) |
| { |
| result--; |
| } |
| } |
| return CreateResult(result, DataType.Integer); |
| } |
| } |
| } |