| using System; |
| using System.Collections.Generic; |
| using System.Globalization; |
| using System.Linq; |
| using System.Text; |
| using System.Text.RegularExpressions; |
| using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime; |
| using OfficeOpenXml.FormulaParsing.ExpressionGraph; |
| |
| namespace OfficeOpenXml.FormulaParsing.Excel.Functions.Text |
| { |
| public class Value : ExcelFunction |
| { |
| private readonly string _groupSeparator = CultureInfo.CurrentCulture.NumberFormat.NumberGroupSeparator; |
| private readonly string _decimalSeparator = CultureInfo.CurrentCulture.NumberFormat.NumberDecimalSeparator; |
| private readonly string _timeSeparator = CultureInfo.CurrentCulture.DateTimeFormat.TimeSeparator; |
| private readonly string _shortTimePattern = CultureInfo.CurrentCulture.DateTimeFormat.ShortTimePattern; |
| private readonly DateValue _dateValueFunc = new DateValue(); |
| private readonly TimeValue _timeValueFunc = new TimeValue(); |
| |
| public override CompileResult Execute(IEnumerable<FunctionArgument> arguments, ParsingContext context) |
| { |
| ValidateArguments(arguments, 1); |
| var val = ArgToString(arguments, 0).TrimEnd(' '); |
| double result = 0d; |
| if (Regex.IsMatch(val, $"^[\\d]*({Regex.Escape(_groupSeparator)}?[\\d]*)?({Regex.Escape(_decimalSeparator)}[\\d]*)?[ ?% ?]?$")) |
| { |
| if (val.EndsWith("%")) |
| { |
| val = val.TrimEnd('%'); |
| result = double.Parse(val) / 100; |
| } |
| else |
| { |
| result = double.Parse(val); |
| } |
| return CreateResult(result, DataType.Decimal); |
| } |
| if (double.TryParse(val, NumberStyles.Float, CultureInfo.CurrentCulture, out result)) |
| { |
| return CreateResult(result, DataType.Decimal); |
| } |
| var timeSeparator = Regex.Escape(_timeSeparator); |
| if (Regex.IsMatch(val, @"^[\d]{1,2}" + timeSeparator + @"[\d]{2}(" + timeSeparator + @"[\d]{2})?$")) |
| { |
| var timeResult = _timeValueFunc.Execute(val); |
| if (timeResult.DataType == DataType.Date) |
| { |
| return timeResult; |
| } |
| } |
| var dateResult = _dateValueFunc.Execute(val); |
| if (dateResult.DataType == DataType.Date) |
| { |
| return dateResult; |
| } |
| return CreateResult(ExcelErrorValue.Create(eErrorType.Value), DataType.ExcelError); |
| } |
| } |
| } |