Ejemplo n.º 1
0
 public ExcelValue FIXED(List <ExcelValue> args, ExpressionScope scope)
 {
     if (args.ContainErrorValues())
     {
         return(ExcelValue.NA);
     }
     if (args.NotDecimal(0, null, out double num))
     {
         return(ExcelValue.VALUE);
     }
     if (args.NotInteger(1, 2, out int decimals))
     {
         return(ExcelValue.VALUE);
     }
     if (args.NotBoolean(2, false, out bool noComma))
     {
         return(ExcelValue.VALUE);
     }
     if (decimals < 0)
     {
         var factor = Math.Pow(10, -decimals);
         num      = Math.Round(num / factor, 0) * factor;
         decimals = 0;
     }
     return(new ExcelValue.DecimalValue(num, scope.OutLanguage,
                                        noComma ? ExpressionFormat.CreateFixedPoint(decimals) : ExpressionFormat.CreateNumeric(decimals)));
 }
Ejemplo n.º 2
0
 internal override string ToString(Language language, ExpressionFormat info)
 {
     if (info != null)
     {
         return(language.ToString((double)InnerValue, info));
     }
     return(Text);
 }
Ejemplo n.º 3
0
        public ValueFormat GetFormat(ExpressionFormat defaultFormat)
        {
            var format = Resolve();

            if (format == null && defaultFormat != null)
            {
                format = defaultFormat.Resolve();
            }
            return(format ?? TranslateExcelStandardFormat(0));
        }
Ejemplo n.º 4
0
            internal override string ToString(Language language, ExpressionFormat info)
            {
                if (info == null)
                {
                    info = Format;
                }
                var date = FromDateSerial(Serial);

                if (date.HasValue)
                {
                    return(language.ToString(date.Value, info));
                }
                return(NA.ToString());
            }
Ejemplo n.º 5
0
        public ExcelValue TEXT(List <ExcelValue> args, ExpressionScope scope)
        {
            if (args.NotText(1, null, scope.OutLanguage, out string format))
            {
                return(ExcelValue.NA);
            }
            var exprFormat = new ExpressionFormat(null, format, scope.OutLanguage.NumberFormat);

            //if (args[0] is ExcelValue.DateValue)
            //{
            //    var date = ((ExcelValue.DateValue)args[0]).Date;
            //    return new ExcelValue.TextValue(scope.OutLanguage.ToString(date, exprFormat), scope.OutLanguage);
            //}
            //else
            //{
            if (args.NotDecimal(0, null, out double value))
            {
                return(ExcelValue.NA);
            }
            return(new ExcelValue.TextValue(scope.OutLanguage.ToString(value, exprFormat), scope.OutLanguage));
            //}
        }
Ejemplo n.º 6
0
 public DecimalValue(double value, Language language, ExpressionFormat format = null)
     : base(value, language.ToString(value, format), language)
 {
 }
Ejemplo n.º 7
0
 public DateValue(double serial, Language language, ExpressionFormat format)
     : base(serial, language, ExpressionFormat.General)
 {
     Serial = serial;
     Format = format;
 }
Ejemplo n.º 8
0
 internal override string ToString(Language language, ExpressionFormat info)
 {
     return(Text);
 }
Ejemplo n.º 9
0
 internal abstract string ToString(Language language, ExpressionFormat info);
Ejemplo n.º 10
0
        internal static ExcelValue CreateDateValue(int year, int month, int day, int hours, int minutes, int seconds, Language language, ExpressionFormat format)
        {
            var serial = ToDateSerial(year, month, day, hours, minutes, seconds);

            if (serial.HasValue)
            {
                return(new DateValue(serial.Value, language, format));
            }
            return(NA);
        }
Ejemplo n.º 11
0
 internal static ExcelValue CreateDateValue(int year, int month, int day, Language language, ExpressionFormat format)
 {
     return(CreateDateValue(year, month, day, 0, 0, 0, language, format));
 }