Formula
Formulas are one of the core capabilities provided by Univer, allowing you to use formulas in cells to calculate values. The functions supported by formulas are consistent with Excel, including mathematical, logical, text, date functions, and more.
Configuration
Following are the links to the configuration items related to the formula plugin:
| Plugin | Configuration Item | 
|---|---|
| @univerjs/engine-formula | IUniverEngineFormulaConfig | 
| @univerjs/sheets-formula | IUniverSheetsFormulaBaseConfig | 
Presets Configuration
import type { CalculationMode } from '@univerjs/preset-sheets-core'
import { UniverSheetsCorePreset } from '@univerjs/preset-sheets-core'
interface IUniverSheetsCorePresetConfig {
  formula?: {
    // Custom formula functions
    function?: Array<[Ctor<BaseFunction>, IFunctionNames]>
    // Custom formula descriptions
    description?: IFunctionInfo[]
    // Defines the calculation mode for formulas during data initialization, default is `WHEN_EMPTY`
    initialFormulaComputing?: CalculationMode
  }
}Plugin Configuration
import type { CalculationMode } from '@univerjs/sheets-formula'
import { UniverSheetsFormulaPlugin } from '@univerjs/sheets-formula'
interface IUniverSheetsFormulaConfig {
  // Custom formula functions
  function?: Array<[Ctor<BaseFunction>, IFunctionNames]>
  // Custom formula descriptions
  description?: IFunctionInfo[]
  // Defines the calculation mode for formulas during data initialization, default is `WHEN_EMPTY`
  initialFormulaComputing?: CalculationMode
}The definition of CalculationMode is as follows:
enum CalculationMode {
  /**
   * Force calculation of all formulas
   */
  FORCED,
  /**
   * Partial calculation, only calculates cells with formulas but no value
   */
  WHEN_EMPTY,
  /**
   * No calculation for all formulas
   */
  NO_CALCULATION,
}If the cell containing the formula has an unexpected value, you can set
initialFormulaComputingtoFORCEDto force the calculation of all formulas. Alternatively, you can clear the cell's value before initialization.
Supported Formula Functions
Functions - (528)
| ACCRINT | Returns the accrued interest for a security that pays periodic interest | 
|---|---|
| ACCRINTM | Returns the accrued interest for a security that pays interest at maturity | 
| AMORDEGRC | Returns the depreciation for each accounting period by using a depreciation coefficient | 
| AMORLINC | Returns the depreciation for each accounting period | 
| COUPDAYBS | Returns the number of days from the beginning of the coupon period to the settlement date | 
| COUPDAYS | Returns the number of days in the coupon period that contains the settlement date | 
| COUPDAYSNC | Returns the number of days from the settlement date to the next coupon date | 
| COUPNCD | Returns the next coupon date after the settlement date | 
| COUPNUM | Returns the number of coupons payable between the settlement date and maturity date | 
| COUPPCD | Returns the previous coupon date before the settlement date | 
| CUMIPMT | Returns the cumulative interest paid between two periods | 
| CUMPRINC | Returns the cumulative principal paid on a loan between two periods | 
| DB | Returns the depreciation of an asset for a specified period by using the fixed-declining balance method | 
| DDB | Returns the depreciation of an asset for a specified period by using the double-declining balance method or some other method that you specify | 
| DISC | Returns the discount rate for a security | 
| DOLLARDE | Converts a dollar price, expressed as a fraction, into a dollar price, expressed as a decimal number | 
| DOLLARFR | Converts a dollar price, expressed as a decimal number, into a dollar price, expressed as a fraction | 
| DURATION | Returns the annual duration of a security with periodic interest payments | 
| EFFECT | Returns the effective annual interest rate | 
| FV | Returns the future value of an investment | 
| FVSCHEDULE | Returns the future value of an initial principal after applying a series of compound interest rates | 
| INTRATE | Returns the interest rate for a fully invested security | 
| IPMT | Returns the interest payment for an investment for a given period | 
| IRR | Returns the internal rate of return for a series of cash flows | 
| ISPMT | Calculates the interest paid during a specific period of an investment | 
| MDURATION | Returns the Macauley modified duration for a security with an assumed par value of $100 | 
| MIRR | Returns the internal rate of return where positive and negative cash flows are financed at different rates | 
| NOMINAL | Returns the annual nominal interest rate | 
| NPER | Returns the number of periods for an investment | 
| NPV | Returns the net present value of an investment based on a series of periodic cash flows and a discount rate | 
| ODDFPRICE | Returns the price per $100 face value of a security with an odd first period | 
| ODDFYIELD | Returns the yield of a security with an odd first period | 
| ODDLPRICE | Returns the price per $100 face value of a security with an odd last period | 
| ODDLYIELD | Returns the yield of a security with an odd last period | 
| PDURATION | Returns the number of periods required by an investment to reach a specified value | 
| PMT | Returns the periodic payment for an annuity | 
| PPMT | Returns the payment on the principal for an investment for a given period | 
| PRICE | Returns the price per $100 face value of a security that pays periodic interest | 
| PRICEDISC | Returns the price per $100 face value of a discounted security | 
| PRICEMAT | Returns the price per $100 face value of a security that pays interest at maturity | 
| PV | Returns the present value of an investment | 
| RATE | Returns the interest rate per period of an annuity | 
| RECEIVED | Returns the amount received at maturity for a fully invested security | 
| RRI | Returns an equivalent interest rate for the growth of an investment | 
| SLN | Returns the straight-line depreciation of an asset for one period | 
| SYD | Returns the sum-of-years' digits depreciation of an asset for a specified period | 
| TBILLEQ | Returns the bond-equivalent yield for a Treasury bill | 
| TBILLPRICE | Returns the price per $100 face value for a Treasury bill | 
| TBILLYIELD | Returns the yield for a Treasury bill | 
| VDB | Returns the depreciation of an asset for a specified or partial period by using a declining balance method | 
| XIRR | Returns the internal rate of return for a schedule of cash flows that is not necessarily periodic | 
| XNPV | Returns the net present value for a schedule of cash flows that is not necessarily periodic | 
| YIELD | Returns the yield on a security that pays periodic interest | 
| YIELDDISC | Returns the annual yield for a discounted security; for example, a Treasury bill | 
| YIELDMAT | Returns the annual yield of a security that pays interest at maturity | 
| DATE | Returns the serial number of a particular date | 
| DATEDIF | Calculates the number of days, months, or years between two dates. This function is useful in formulas where you need to calculate an age. | 
| DATEVALUE | Converts a date in the form of text to a serial number. | 
| DAY | Returns the day of a date, represented by a serial number. The day is given as an integer ranging from 1 to 31. | 
| DAYS | Returns the number of days between two dates | 
| DAYS360 | Calculates the number of days between two dates based on a 360-day year | 
| EDATE | Returns the serial number that represents the date that is the indicated number of months before or after a specified date (the start_date). Use EDATE to calculate maturity dates or due dates that fall on the same day of the month as the date of issue. | 
| EOMONTH | Returns the serial number of the last day of the month before or after a specified number of months | 
| EPOCHTODATE | Converts a Unix epoch timestamp in seconds, milliseconds, or microseconds to a datetime in Universal Time Coordinated (UTC). | 
| HOUR | Converts a serial number to an hour | 
| ISOWEEKNUM | Returns the number of the ISO week number of the year for a given date | 
| MINUTE | Converts a serial number to a minute | 
| MONTH | Returns the month of a date represented by a serial number. The month is given as an integer, ranging from 1 (January) to 12 (December). | 
| NETWORKDAYS | Returns the number of whole workdays between two dates | 
| NETWORKDAYS_INTL | Returns the number of whole workdays between two dates using parameters to indicate which and how many days are weekend days | 
| NOW | Returns the serial number of the current date and time. | 
| SECOND | Converts a serial number to a second | 
| TIME | Returns the serial number of a particular time. | 
| TIMEVALUE | Converts a time in the form of text to a serial number. | 
| TO_DATE | Converts a provided number to a date. | 
| TODAY | Returns the serial number of today's date | 
| WEEKDAY | Converts a serial number to a day of the week | 
| WEEKNUM | Converts a serial number to a number representing where the week falls numerically with a year | 
| WORKDAY | Returns the serial number of the date before or after a specified number of workdays | 
| WORKDAY_INTL | Returns the serial number of the date before or after a specified number of workdays using parameters to indicate which and how many days are weekend days | 
| YEAR | Returns the year corresponding to a date. The year is returned as an integer in the range 1900-9999. | 
| YEARFRAC | Returns the year fraction representing the number of whole days between start_date and end_date | 
| ABS | Returns the absolute value of a number. The absolute value of a number is the number without its sign. | 
| ACOS | Returns the arccosine, or inverse cosine, of a number. The arccosine is the angle whose cosine is number. The returned angle is given in radians in the range 0 (zero) to pi. | 
| ACOSH | Returns the inverse hyperbolic cosine of a number. The number must be greater than or equal to 1. The inverse hyperbolic cosine is the value whose hyperbolic cosine is number, so ACOSH(COSH(number)) equals number. | 
| ACOT | Returns the principal value of the arccotangent, or inverse cotangent, of a number. | 
| ACOTH | Returns the hyperbolic arccotangent of a number | 
| AGGREGATE | Returns an aggregate in a list or database | 
| ARABIC | Converts a Roman number to Arabic, as a number | 
| ASIN | Returns the arcsine of a number. | 
| ASINH | Returns the inverse hyperbolic sine of a number. | 
| ATAN | Returns the arctangent of a number. | 
| ATAN2 | Returns the arctangent from x- and y-coordinates. | 
| ATANH | Returns the inverse hyperbolic tangent of a number. | 
| BASE | Converts a number into a text representation with the given radix (base) | 
| CEILING | Rounds a number to the nearest integer or to the nearest multiple of significance | 
| CEILING_MATH | Rounds a number up, to the nearest integer or to the nearest multiple of significance | 
| CEILING_PRECISE | Rounds a number the nearest integer or to the nearest multiple of significance. Regardless of the sign of the number, the number is rounded up. | 
| COMBIN | Returns the number of combinations for a given number of objects | 
| COMBINA | Returns the number of combinations with repetitions for a given number of items | 
| COS | Returns the cosine of a number. | 
| COSH | Returns the hyperbolic cosine of a number | 
| COT | Returns the cotangent of an angle | 
| COTH | Returns the hyperbolic cotangent of a number | 
| CSC | Returns the cosecant of an angle | 
| CSCH | Returns the hyperbolic cosecant of an angle | 
| DECIMAL | Converts a text representation of a number in a given base into a decimal number | 
| DEGREES | Converts radians to degrees | 
| EVEN | Rounds a number up to the nearest even integer | 
| EXP | Returns e raised to the power of a given number | 
| FACT | Returns the factorial of a number | 
| FACTDOUBLE | Returns the double factorial of a number | 
| FLOOR | Rounds a number down, toward zero | 
| FLOOR_MATH | Rounds a number down, to the nearest integer or to the nearest multiple of significance | 
| FLOOR_PRECISE | Rounds a number down to the nearest integer or to the nearest multiple of significance. Regardless of the sign of the number, the number is rounded down. | 
| GCD | Returns the greatest common divisor | 
| INT | Rounds a number down to the nearest integer | 
| ISO_CEILING | Returns a number that is rounded up to the nearest integer or to the nearest multiple of significance | 
| LCM | Returns the least common multiple | 
| LET | Assigns names to calculation results | 
| LN | Returns the natural logarithm of a number | 
| LOG | Returns the logarithm of a number to a specified base | 
| LOG10 | Returns the base-10 logarithm of a number | 
| MDETERM | Returns the matrix determinant of an array | 
| MINVERSE | Returns the matrix inverse of an array | 
| MMULT | Returns the matrix product of two arrays | 
| MOD | Returns the remainder after number is divided by divisor. The result has the same sign as divisor. | 
| MROUND | Returns a number rounded to the desired multiple | 
| MULTINOMIAL | Returns the multinomial of a set of numbers | 
| MUNIT | Returns the unit matrix or the specified dimension | 
| ODD | Rounds a number up to the nearest odd integer | 
| PI | Returns the value of pi | 
| POWER | Returns the result of a number raised to a power. | 
| PRODUCT | Multiplies all the numbers given as arguments and returns the product. | 
| QUOTIENT | Returns the integer portion of a division | 
| RADIANS | Converts degrees to radians | 
| RAND | Returns a random number between 0 and 1 | 
| RANDARRAY | Returns an array of random numbers between 0 and 1. However, you can specify the number of rows and columns to fill, minimum and maximum values, and whether to return whole numbers or decimal values. | 
| RANDBETWEEN | Returns a random number between the numbers you specify | 
| ROMAN | Converts an Arabic numeral to Roman, as text | 
| ROUND | Rounds a number to a specified number of digits | 
| ROUNDBANK | Rounds a number in banker's rounding | 
| ROUNDDOWN | Rounds a number down, toward zero | 
| ROUNDUP | Rounds a number up, away from zero | 
| SEC | Returns the secant of an angle | 
| SECH | Returns the hyperbolic secant of an angle | 
| SERIESSUM | Returns the sum of a power series based on the formula | 
| SEQUENCE | Generates a list of sequential numbers in an array, such as 1, 2, 3, 4 | 
| SIGN | Returns the sign of a number | 
| SIN | Returns the sine of the given angle | 
| SINH | Returns the hyperbolic sine of a number | 
| SQRT | Returns a positive square root | 
| SQRTPI | Returns the square root of (number * pi) | 
| SUBTOTAL | Returns a subtotal in a list or database. | 
| SUM | You can add individual values, cell references or ranges or a mix of all three. | 
| SUMIF | Sum the values in a range that meet criteria that you specify. | 
| SUMIFS | Adds all of its arguments that meet multiple criteria. | 
| SUMPRODUCT | Returns the sum of the products of corresponding array components | 
| SUMSQ | Returns the sum of the squares of the arguments | 
| SUMX2MY2 | Returns the sum of the difference of squares of corresponding values in two arrays | 
| SUMX2PY2 | Returns the sum of the sum of squares of corresponding values in two arrays | 
| SUMXMY2 | Returns the sum of squares of differences of corresponding values in two arrays | 
| TAN | Returns the tangent of a number. | 
| TANH | Returns the hyperbolic tangent of a number. | 
| TRUNC | Truncates a number to an integer | 
| AVEDEV | Returns the average of the absolute deviations of data points from their mean. | 
| AVERAGE | Returns the average (arithmetic mean) of the arguments. | 
| AVERAGE_WEIGHTED | Finds the weighted average of a set of values, given the values and the corresponding weights. | 
| AVERAGEA | Returns the average of its arguments, including numbers, text, and logical values. | 
| AVERAGEIF | Returns the average (arithmetic mean) of all the cells in a range that meet a given criteria. | 
| AVERAGEIFS | Returns the average (arithmetic mean) of all cells that meet multiple criteria. | 
| BETA_DIST | Returns the beta cumulative distribution function | 
| BETA_INV | Returns the inverse of the cumulative distribution function for a specified beta distribution | 
| BINOM_DIST | Returns the individual term binomial distribution probability | 
| BINOM_DIST_RANGE | Returns the probability of a trial result using a binomial distribution | 
| BINOM_INV | Returns the smallest value for which the cumulative binomial distribution is less than or equal to a criterion value | 
| CHISQ_DIST | Returns the left-tailed probability of the chi-squared distribution. | 
| CHISQ_DIST_RT | Returns the right-tailed probability of the chi-squared distribution. | 
| CHISQ_INV | Returns the inverse of the left-tailed probability of the chi-squared distribution. | 
| CHISQ_INV_RT | Returns the inverse of the right-tailed probability of the chi-squared distribution. | 
| CHISQ_TEST | Returns the test for independence | 
| CONFIDENCE_NORM | Returns the confidence interval for a population mean, using a normal distribution. | 
| CONFIDENCE_T | Returns the confidence interval for a population mean, using a Student's t distribution | 
| CORREL | Returns the correlation coefficient between two data sets | 
| COUNT | Counts the number of cells that contain numbers, and counts numbers within the list of arguments. | 
| COUNTA | Counts cells containing any type of information, including error values and empty text ("") If you do not need to count logical values, text, or error values | 
| COUNTBLANK | Counts the number of blank cells within a range. | 
| COUNTIF | Counts the number of cells within a range that meet the given criteria. | 
| COUNTIFS | Counts the number of cells within a range that meet multiple criteria. | 
| COVARIANCE_P | Returns population covariance, the average of the products of deviations for each data point pair in two data sets. | 
| COVARIANCE_S | Returns the sample covariance, the average of the products of deviations for each data point pair in two data sets. | 
| DEVSQ | Returns the sum of squares of deviations | 
| EXPON_DIST | Returns the exponential distribution | 
| F_DIST | Returns the F probability distribution | 
| F_DIST_RT | Returns the (right-tailed) F probability distribution | 
| F_INV | Returns the inverse of the F probability distribution | 
| F_INV_RT | Returns the inverse of the (right-tailed) F probability distribution | 
| F_TEST | Returns the result of an F-test | 
| FISHER | Returns the Fisher transformation | 
| FISHERINV | Returns the inverse of the Fisher transformation | 
| FORECAST | Returns a value along a linear trend | 
| FORECAST_ETS | Returns a future value based on existing (historical) values by using the AAA version of the Exponential Smoothing (ETS) algorithm | 
| FORECAST_ETS_CONFINT | Returns a confidence interval for the forecast value at the specified target date | 
| FORECAST_ETS_SEASONALITY | Returns the length of the repetitive pattern Excel detects for the specified time series | 
| FORECAST_ETS_STAT | Returns a statistical value as a result of time series forecasting | 
| FORECAST_LINEAR | Returns a future value based on existing values | 
| FREQUENCY | Returns a frequency distribution as a vertical array | 
| GAMMA | Returns the Gamma function value | 
| GAMMA_DIST | Returns the gamma distribution | 
| GAMMA_INV | Returns the inverse of the gamma cumulative distribution | 
| GAMMALN | Returns the natural logarithm of the gamma function, Γ(x) | 
| GAMMALN_PRECISE | Returns the natural logarithm of the gamma function, Γ(x) | 
| GAUSS | Returns 0.5 less than the standard normal cumulative distribution | 
| GEOMEAN | Returns the geometric mean | 
| GROWTH | Returns values along an exponential trend | 
| HARMEAN | Returns the harmonic mean | 
| HYPGEOM_DIST | Returns the hypergeometric distribution | 
| INTERCEPT | Returns the intercept of the linear regression line | 
| KURT | Returns the kurtosis of a data set | 
| LARGE | Returns the k-th largest value in a data set | 
| LINEST | Returns the parameters of a linear trend | 
| LOGEST | Returns the parameters of an exponential trend | 
| LOGNORM_DIST | Returns the cumulative lognormal distribution | 
| LOGNORM_INV | Returns the inverse of the lognormal cumulative distribution | 
| MARGINOFERROR | Calculates the margin of error from a range of values and a confidence level. | 
| MAX | Returns the largest value in a set of values. | 
| MAXA | Returns the maximum value in a list of arguments, including numbers, text, and logical values. | 
| MAXIFS | Returns the maximum value among cells specified by a given set of conditions or criteria. | 
| MEDIAN | Returns the median of the given numbers | 
| MIN | Returns the smallest number in a set of values. | 
| MINA | Returns the smallest value in a list of arguments, including numbers, text, and logical values | 
| MINIFS | Returns the minimum value among cells specified by a given set of conditions or criteria. | 
| MODE_MULT | Returns a vertical array of the most frequently occurring, or repetitive values in an array or range of data | 
| MODE_SNGL | Returns the most common value in a data set | 
| NEGBINOM_DIST | Returns the negative binomial distribution | 
| NORM_DIST | Returns the normal cumulative distribution | 
| NORM_INV | Returns the inverse of the normal cumulative distribution | 
| NORM_S_DIST | Returns the standard normal cumulative distribution | 
| NORM_S_INV | Returns the inverse of the standard normal cumulative distribution | 
| PEARSON | Returns the Pearson product moment correlation coefficient | 
| PERCENTILE_EXC | Returns the k-th percentile of values in a data set (Excludes 0 and 1). | 
| PERCENTILE_INC | Returns the k-th percentile of values in a data set (Includes 0 and 1) | 
| PERCENTRANK_EXC | Returns the percentage rank of a value in a data set (Excludes 0 and 1) | 
| PERCENTRANK_INC | Returns the percentage rank of a value in a data set (Includes 0 and 1) | 
| PERMUT | Returns the number of permutations for a given number of objects | 
| PERMUTATIONA | Returns the number of permutations for a given number of objects (with repetitions) that can be selected from the total objects | 
| PHI | Returns the value of the density function for a standard normal distribution | 
| POISSON_DIST | Returns the Poisson distribution | 
| PROB | Returns the probability that values in a range are between two limits | 
| QUARTILE_EXC | Returns the quartile of a data set (Excludes 0 and 1) | 
| QUARTILE_INC | Returns the quartile of a data set (Includes 0 and 1) | 
| RANK_AVG | Returns the rank of a number in a list of numbers | 
| RANK_EQ | Returns the rank of a number in a list of numbers | 
| RSQ | Returns the square of the Pearson product moment correlation coefficient | 
| SKEW | Returns the skewness of a distribution | 
| SKEW_P | Returns the skewness of a distribution based on a population | 
| SLOPE | Returns the slope of the linear regression line | 
| SMALL | Returns the k-th smallest value in a data set | 
| STANDARDIZE | Returns a normalized value | 
| STDEV_P | Calculates standard deviation based on the entire population given as arguments (ignores logical values and text). | 
| STDEV_S | Estimates standard deviation based on a sample (ignores logical values and text in the sample). | 
| STDEVA | Estimates standard deviation based on a sample, including numbers, text, and logical values. | 
| STDEVPA | Calculates standard deviation based on the entire population given as arguments, including text and logical values. | 
| STEYX | Returns the standard error of the predicted y-value for each x in the regression | 
| T_DIST | Returns the probability for the Student t-distribution | 
| T_DIST_2T | Returns the probability for the Student t-distribution (two-tailed) | 
| T_DIST_RT | Returns the probability for the Student t-distribution (right-tailed) | 
| T_INV | Returns the inverse of the probability for the Student t-distribution | 
| T_INV_2T | Returns the inverse of the probability for the Student t-distribution (two-tailed) | 
| T_TEST | Returns the probability associated with a Student's t-test | 
| TREND | Returns values along a linear trend | 
| TRIMMEAN | Returns the mean of the interior of a data set | 
| VAR_P | Calculates variance based on the entire population (ignores logical values and text in the population). | 
| VAR_S | Estimates variance based on a sample (ignores logical values and text in the sample). | 
| VARA | Estimates variance based on a sample, including numbers, text, and logical values | 
| VARPA | Calculates variance based on the entire population, including numbers, text, and logical values | 
| WEIBULL_DIST | Returns the Weibull distribution | 
| Z_TEST | Returns the one-tailed probability-value of a z-test | 
| ADDRESS | Obtain the address of a cell in a worksheet, given specified row and column numbers. For example, ADDRESS(2,3) returns $C$2. As another example, ADDRESS(77,300) returns $KN$77. You can use other functions, such as the ROW and COLUMN functions, to provide the row and column number arguments for the ADDRESS function. | 
| AREAS | Returns the number of areas in a reference | 
| CHOOSE | Chooses a value from a list of values. | 
| CHOOSECOLS | Returns the specified columns from an array | 
| CHOOSEROWS | Returns the specified rows from an array | 
| COLUMN | Returns the column number of the given cell reference. | 
| COLUMNS | Returns the number of columns in an array or reference. | 
| DROP | Excludes a specified number of rows or columns from the start or end of an array | 
| EXPAND | Expands or pads an array to specified row and column dimensions | 
| FILTER | Filters a range of data based on criteria you define | 
| FORMULATEXT | Returns the formula at the given reference as text | 
| GETPIVOTDATA | Returns data stored in a PivotTable report | 
| HLOOKUP | Looks in the top row of an array and returns the value of the indicated cell | 
| HSTACK | Appends arrays horizontally and in sequence to return a larger array | 
| HYPERLINK | Creates a hyperlink inside a cell. | 
| IMAGE | Returns an image from a given source | 
| INDEX | Returns the reference of the cell at the intersection of a particular row and column. If the reference is made up of non-adjacent selections, you can pick the selection to look in. | 
| INDIRECT | Returns the reference specified by a text string. References are immediately evaluated to display their contents. | 
| LOOKUP | When you need to look in a single row or column and find a value from the same position in a second row or column | 
| MATCH | The MATCH function searches for a specified item in a range of cells, and then returns the relative position of that item in the range. | 
| OFFSET | Returns a reference offset from a given reference | 
| ROW | Returns the row number of a reference | 
| ROWS | Returns the number of rows in an array or reference. | 
| RTD | Retrieves real-time data from a program that supports COM automation | 
| SORT | Sorts the contents of a range or array | 
| SORTBY | Sorts the contents of a range or array based on the values in a corresponding range or array | 
| TAKE | Returns a specified number of contiguous rows or columns from the start or end of an array | 
| TOCOL | Returns the array in a single column | 
| TOROW | Returns the array in a single row | 
| TRANSPOSE | Returns the transpose of an array | 
| UNIQUE | Returns a list of unique values in a list or range | 
| VLOOKUP | Use VLOOKUP when you need to find things in a table or a range by row. For example, look up a price of an automotive part by the part number, or find an employee name based on their employee ID. | 
| VSTACK | Appends arrays vertically and in sequence to return a larger array | 
| WRAPCOLS | Wraps the provided row or column of values by columns after a specified number of elements | 
| WRAPROWS | Wraps the provided row or column of values by rows after a specified number of elements | 
| XLOOKUP | Searches a range or an array, and returns an item corresponding to the first match it finds. If a match doesn't exist, then XLOOKUP can return the closest (approximate) match. | 
| XMATCH | Searches for a specified item in an array or range of cells, and then returns the item's relative position. | 
| DAVERAGE | Returns the average of selected database entries | 
| DCOUNT | Counts the cells that contain numbers in a database | 
| DCOUNTA | Counts nonblank cells in a database | 
| DGET | Extracts from a database a single record that matches the specified criteria | 
| DMAX | Returns the maximum value from selected database entries | 
| DMIN | Returns the minimum value from selected database entries | 
| DPRODUCT | Multiplies the values in a particular field of records that match the criteria in a database | 
| DSTDEV | Estimates the standard deviation based on a sample of selected database entries | 
| DSTDEVP | Calculates the standard deviation based on the entire population of selected database entries | 
| DSUM | Adds the numbers in the field column of records in the database that match the criteria | 
| DVAR | Estimates variance based on a sample from selected database entries | 
| DVARP | Calculates variance based on the entire population of selected database entries | 
| ASC | Changes full-width (double-byte) English letters or katakana within a character string to half-width (single-byte) characters | 
| ARRAYTOTEXT | Returns an array of text values from any specified range | 
| BAHTTEXT | Converts a number to text, using the ß (baht) currency format | 
| CHAR | Returns the character specified by the code number | 
| CLEAN | Removes all nonprintable characters from text | 
| CODE | Returns a numeric code for the first character in a text string | 
| CONCAT | Combines the text from multiple ranges and/or strings, but it doesn't provide the delimiter or IgnoreEmpty arguments. | 
| CONCATENATE | Joins several text items into one text item | 
| DBCS | Changes half-width (single-byte) English letters or katakana within a character string to full-width (double-byte) characters | 
| DOLLAR | Converts a number to text using currency format | 
| EXACT | Checks to see if two text values are identical | 
| FIND | Finds one text value within another (case-sensitive) | 
| FINDB | Finds one text value within another (case-sensitive) | 
| FIXED | Formats a number as text with a fixed number of decimals | 
| LEFT | Returns the leftmost characters from a text value | 
| LEFTB | Returns the leftmost characters from a text value | 
| LEN | Returns the number of characters in a text string | 
| LENB | Returns the number of bytes used to represent the characters in a text string. | 
| LOWER | Converts text to lowercase. | 
| MID | Returns a specific number of characters from a text string starting at the position you specify. | 
| MIDB | Returns a specific number of characters from a text string starting at the position you specify | 
| NUMBERSTRING | Convert numbers to Chinese strings | 
| NUMBERVALUE | Converts text to number in a locale-independent manner | 
| PHONETIC | Extracts the phonetic (furigana) characters from a text string | 
| PROPER | Capitalizes the first letter in each word of a text value | 
| REGEXEXTRACT | Extracts the first matching substrings according to a regular expression. | 
| REGEXMATCH | Whether a piece of text matches a regular expression. | 
| REGEXREPLACE | Replaces part of a text string with a different text string using regular expressions. | 
| REPLACE | Replaces characters within text | 
| REPLACEB | Replaces characters within text | 
| REPT | Repeats text a given number of times | 
| RIGHT | Returns the rightmost characters from a text value | 
| RIGHTB | Returns the rightmost characters from a text value | 
| SEARCH | Finds one text value within another (not case-sensitive) | 
| SEARCHB | Finds one text value within another (not case-sensitive) | 
| SUBSTITUTE | Substitutes new text for old text in a text string | 
| T | Converts its arguments to text | 
| TEXT | Formats a number and converts it to text | 
| TEXTAFTER | Returns text that occurs after given character or string | 
| TEXTBEFORE | Returns text that occurs before a given character or string | 
| TEXTJOIN | Text: Combines the text from multiple ranges and/or strings | 
| TEXTSPLIT | Splits text strings by using column and row delimiters | 
| TRIM | Removes all spaces from text except for single spaces between words. | 
| UNICHAR | Returns the Unicode character that is references by the given numeric value | 
| UNICODE | Returns the number (code point) that corresponds to the first character of the text | 
| UPPER | Converts text to uppercase | 
| VALUE | Converts a text argument to a number | 
| VALUETOTEXT | Returns text from any specified value | 
| CALL | Calls a procedure in a dynamic link library or code resource | 
| EUROCONVERT | Converts a number to euros, converts a number from euros to a euro member currency, or converts a number from one euro member currency to another by using the euro as an intermediary (triangulation) | 
| REGISTER_ID | Returns the register ID of the specified dynamic link library (DLL) or code resource that has been previously registered | 
| AND | Returns TRUE if all of its arguments are TRUE | 
| BYCOL | Applies a LAMBDA to each column and returns an array of the results | 
| BYROW | Applies a LAMBDA to each row and returns an array of the results | 
| FALSE | Returns the logical value FALSE. | 
| IF | Specifies a logical test to perform | 
| IFERROR | Returns a value you specify if a formula evaluates to an error; otherwise, returns the result of the formula | 
| IFNA | Returns the value you specify if the expression resolves to #N/A, otherwise returns the result of the expression | 
| IFS | Checks whether one or more conditions are met and returns a value that corresponds to the first TRUE condition. | 
| LAMBDA | Use a LAMBDA function to create custom, reusable functions and call them by a friendly name. The new function is available throughout the workbook and called like native Excel functions. | 
| MAKEARRAY | Returns a calculated array of a specified row and column size, by applying a LAMBDA | 
| MAP | Returns an array formed by mapping each value in the array(s) to a new value by applying a LAMBDA to create a new value. | 
| NOT | Reverses the logic of its argument. | 
| OR | Returns TRUE if any of its arguments evaluate to TRUE, and returns FALSE if all of its arguments evaluate to FALSE. | 
| REDUCE | Reduces an array to an accumulated value by applying a LAMBDA to each value and returning the total value in the accumulator. | 
| SCAN | Scans an array by applying a LAMBDA to each value and returns an array that has each intermediate value. | 
| SWITCH | Evaluates an expression against a list of values and returns the result corresponding to the first matching value. If there is no match, an optional default value may be returned. | 
| TRUE | Returns the logical value TRUE. | 
| XOR | Returns TRUE if an odd number of its arguments evaluate to TRUE, and FALSE if an even number of its arguments evaluate to TRUE. | 
| CELL | Returns information about the formatting, location, or contents of a cell | 
| ERROR_TYPE | Returns a number corresponding to an error type | 
| INFO | Returns information about the current operating environment | 
| ISBETWEEN | Checks whether a provided number is between two other numbers either inclusively or exclusively. | 
| ISBLANK | Returns TRUE if the value is blank | 
| ISDATE | Returns whether a value is a date. | 
| ISEMAIL | Checks if a value is a valid email address | 
| ISERR | Returns TRUE if the value is any error value except #N/A | 
| ISERROR | Returns TRUE if the value is any error value | 
| ISEVEN | Returns TRUE if the number is even | 
| ISFORMULA | Returns TRUE if there is a reference to a cell that contains a formula | 
| ISLOGICAL | Returns TRUE if the value is a logical value | 
| ISNA | Returns TRUE if the value is the #N/A error value | 
| ISNONTEXT | Returns TRUE if the value is not text | 
| ISNUMBER | Returns TRUE if the value is a number | 
| ISODD | Returns TRUE if the number is odd | 
| ISOMITTED | Checks whether the value in a LAMBDA is missing and returns TRUE or FALSE | 
| ISREF | Returns TRUE if the value is a reference | 
| ISTEXT | Returns TRUE if the value is text | 
| ISURL | Checks whether a value is a valid URL. | 
| N | Returns a value converted to a number | 
| NA | Returns the error value #N/A | 
| SHEET | Returns the sheet number of the referenced sheet | 
| SHEETS | Returns the number of sheets in a workbook | 
| TYPE | Returns a number indicating the data type of a value | 
| BESSELI | Returns the modified Bessel function In(x) | 
| BESSELJ | Returns the Bessel function Jn(x) | 
| BESSELK | Returns the modified Bessel function Kn(x) | 
| BESSELY | Returns the Bessel function Yn(x) | 
| BIN2DEC | Converts a binary number to decimal | 
| BIN2HEX | Converts a binary number to hexadecimal | 
| BIN2OCT | Converts a binary number to octal | 
| BITAND | Returns a 'Bitwise And' of two numbers | 
| BITLSHIFT | Returns a value number shifted left by shift_amount bits | 
| BITOR | Returns a bitwise OR of 2 numbers | 
| BITRSHIFT | Returns a value number shifted right by shift_amount bits | 
| BITXOR | Returns a bitwise 'Exclusive Or' of two numbers | 
| COMPLEX | Converts real and imaginary coefficients into a complex number | 
| CONVERT | Converts a number from one measurement system to another | 
| DEC2BIN | Converts a decimal number to binary | 
| DEC2HEX | Converts a decimal number to hexadecimal | 
| DEC2OCT | Converts a decimal number to octal | 
| DELTA | Tests whether two values are equal | 
| ERF | Returns the error function | 
| ERF_PRECISE | Returns the error function | 
| ERFC | Returns the complementary error function | 
| ERFC_PRECISE | Returns the complementary ERF function integrated between x and infinity | 
| GESTEP | Tests whether a number is greater than a threshold value | 
| HEX2BIN | Converts a hexadecimal number to binary | 
| HEX2DEC | Converts a hexadecimal number to decimal | 
| HEX2OCT | Converts a hexadecimal number to octal | 
| IMABS | Returns the absolute value (modulus) of a complex number | 
| IMAGINARY | Returns the imaginary coefficient of a complex number | 
| IMARGUMENT | Returns the argument theta, an angle expressed in radians | 
| IMCONJUGATE | Returns the complex conjugate of a complex number | 
| IMCOS | Returns the cosine of a complex number | 
| IMCOSH | Returns the hyperbolic cosine of a complex number | 
| IMCOT | Returns the cotangent of a complex number | 
| IMCOTH | Returns the hyperbolic cotangent of a complex number | 
| IMCSC | Returns the cosecant of a complex number | 
| IMCSCH | Returns the hyperbolic cosecant of a complex number | 
| IMDIV | Returns the quotient of two complex numbers | 
| IMEXP | Returns the exponential of a complex number | 
| IMLN | Returns the natural logarithm of a complex number | 
| IMLOG | Returns the logarithm of a complex number for a specified base | 
| IMLOG10 | Returns the base-10 logarithm of a complex number | 
| IMLOG2 | Returns the base-2 logarithm of a complex number | 
| IMPOWER | Returns a complex number raised to an integer power | 
| IMPRODUCT | Returns the product of from 1 to 255 complex numbers | 
| IMREAL | Returns the real coefficient of a complex number | 
| IMSEC | Returns the secant of a complex number | 
| IMSECH | Returns the hyperbolic secant of a complex number | 
| IMSIN | Returns the sine of a complex number | 
| IMSINH | Returns the hyperbolic sine of a complex number | 
| IMSQRT | Returns the square root of a complex number | 
| IMSUB | Returns the difference between two complex numbers | 
| IMSUM | Returns the sum of complex numbers | 
| IMTAN | Returns the tangent of a complex number | 
| IMTANH | Returns the hyperbolic tangent of a complex number | 
| OCT2BIN | Converts an octal number to binary | 
| OCT2DEC | Converts an octal number to decimal | 
| OCT2HEX | Converts an octal number to hexadecimal | 
| CUBEKPIMEMBER | Returns a key performance indicator (KPI) property and displays the KPI name in the cell. A KPI is a quantifiable measurement, such as monthly gross profit or quarterly employee turnover, that is used to monitor an organization's performance. | 
| CUBEMEMBER | Returns a member or tuple from the cube. Use to validate that the member or tuple exists in the cube. | 
| CUBEMEMBERPROPERTY | Returns the value of a member property from the cube. Use to validate that a member name exists within the cube and to return the specified property for this member. | 
| CUBERANKEDMEMBER | Returns the nth, or ranked, member in a set. Use to return one or more elements in a set, such as the top sales performer or the top 10 students. | 
| CUBESET | Defines a calculated set of members or tuples by sending a set expression to the cube on the server, which creates the set, and then returns that set to Microsoft Excel. | 
| CUBESETCOUNT | Returns the number of items in a set. | 
| CUBEVALUE | Returns an aggregated value from the cube. | 
| BETADIST | Returns the beta cumulative distribution function | 
| BETAINV | Returns the inverse of the cumulative distribution function for a specified beta distribution | 
| BINOMDIST | Returns the individual term binomial distribution probability | 
| CHIDIST | Returns the right-tailed probability of the chi-squared distribution. | 
| CHIINV | Returns the inverse of the right-tailed probability of the chi-squared distribution. | 
| CHITEST | Returns the test for independence | 
| CONFIDENCE | Returns the confidence interval for a population mean, using a normal distribution. | 
| COVAR | Returns population covariance, the average of the products of deviations for each data point pair in two data sets. | 
| CRITBINOM | Returns the smallest value for which the cumulative binomial distribution is less than or equal to a criterion value | 
| EXPONDIST | Returns the exponential distribution | 
| FDIST | Returns the (right-tailed) F probability distribution | 
| FINV | Returns the inverse of the (right-tailed) F probability distribution | 
| FTEST | Returns the result of an F-test | 
| GAMMADIST | Returns the gamma distribution | 
| GAMMAINV | Returns the inverse of the gamma cumulative distribution | 
| HYPGEOMDIST | Returns the hypergeometric distribution | 
| LOGINV | Returns the inverse of the lognormal cumulative distribution function | 
| LOGNORMDIST | Returns the cumulative lognormal distribution | 
| MODE | Returns the most common value in a data set | 
| NEGBINOMDIST | Returns the negative binomial distribution | 
| NORMDIST | Returns the normal cumulative distribution | 
| NORMINV | Returns the inverse of the normal cumulative distribution | 
| NORMSDIST | Returns the standard normal cumulative distribution | 
| NORMSINV | Returns the inverse of the standard normal cumulative distribution | 
| PERCENTILE | Returns the k-th percentile of values in a data set (Includes 0 and 1) | 
| PERCENTRANK | Returns the percentage rank of a value in a data set (Includes 0 and 1) | 
| POISSON | Returns the Poisson distribution | 
| QUARTILE | Returns the quartile of a data set (Includes 0 and 1) | 
| RANK | Returns the rank of a number in a list of numbers | 
| STDEV | Estimates standard deviation based on a sample. The standard deviation is a measure of how widely values are dispersed from the average value (the mean). | 
| STDEVP | Calculates standard deviation based on the entire population given as arguments. | 
| TDIST | Returns the probability for the Student t-distribution | 
| TINV | Returns the inverse of the probability for the Student t-distribution (two-tailed) | 
| TTEST | Returns the probability associated with a Student's t-test | 
| VAR | Estimates variance based on a sample. | 
| VARP | Calculates variance based on the entire population. | 
| WEIBULL | Returns the Weibull distribution | 
| ZTEST | Returns the one-tailed probability-value of a z-test | 
| ENCODEURL | Returns a URL-encoded string | 
| FILTERXML | Returns specific data from the XML content by using the specified XPath | 
| WEBSERVICE | Returns data from a web service | 
| ARRAY_CONSTRAIN | Constrains an array result to a specified size. | 
| FLATTEN | Flattens all the values from one or more ranges into a single column. | 
Facade API
Before using the formula API, make sure to import the @univerjs/sheets-formula/facade.
import '@univerjs/sheets-formula/facade'Execute Calculation
const formula = univerAPI.getFormula()
formula.executeCalculation()Stop Calculation
const formula = univerAPI.getFormula()
formula.stopCalculation()Calculation Start Event
const formula = univerAPI.getFormula()
formula.calculationStart((forceCalculate) => {
  console.log(forceCalculate)
})Calculation Processing Event
const formula = univerAPI.getFormula()
formula.calculationProcessing((stageInfo) => {
  console.log(stageInfo)
})Calculation End Event
const formula = univerAPI.getFormula()
formula.calculationEnd((functionsExecutedState) => {
  console.log(functionsExecutedState)
})Set Initial Calculation Mode
const formula = univerAPI.getFormula()
formula.setInitialFormulaComputing(CalculationMode.FORCED)If this API is called after the Starting lifecycle, it will take effect the next time a Univer Sheet is created.
If you want it to take effect during the current initialization of the Univer Sheet, you can consider calling it before the Ready lifecycle, for example:
univerAPI.addEvent(univerAPI.Event.LifeCycleChanged, ({ stage }) => {
  if (stage === LifecycleStages.Starting) {
    const formula = univerAPI.getFormula()
    formula.setInitialFormulaComputing(CalculationMode.FORCED)
  }
})Custom Formulas
Univer supports custom formulas. Please refer to the Custom Formulas section to learn how to implement them.
Frequently Asked Questions
HYPERLINK Formula Cells Cannot Operate Hyperlinks
You need to import the hyperlink plugin for Univer Sheets. See the Hyperlink module.
How is this guide?