Skip to content

Supported Functions

Mats Alm edited this page Jun 23, 2020 · 33 revisions

The following functions are supported by EPPlus 5.2 when evaluating formulas:

Database

Function Description From EPPlus version
DAVERAGE Calculates the average of values in a field of a list or database, that satisfy specified conditions 4
DCOUNT Returns the number of cells containing numbers in a field of a list or database that satisfy specified conditions 4
DCOUNTA Returns the number of non-blank cells in a field of a list or database, that satisfy specified conditions 4
DGET Returns a single value from a field of a list or database, that satisfy specified conditions 4
DMAX Returns the maximum value from a field of a list or database, that satisfy specified conditions 4
DMIN Returns the minimum value from a field of a list or database, that satisfy specified conditions 4
DSUM Calculates the sum of values in a field of a list or database, that satisfy specified conditions 4
DVAR Calculates the variance (based on a sample of a population) of values in a field of a list or database, that satisfy specified conditions 4
DVARP Calculates the variance (based on an entire population) of values in a field of a list or database, that satisfy specified conditions 4

Date and time

Function Description From EPPlus version
DATE Returns a date, from a user-supplied year, month and day 4
DATEVALUE Converts a text string showing a date, to an integer that represents the date in Excel's date-time code 4
DAY Returns the day (of the month) from a user-supplied date 4
DAYS Calculates the number of days between 2 dates 4
DAYS360 Calculates the number of days between 2 dates, based on a 360-day year (12 x 30 months) 4
EDATE Returns a date that is the specified number of months before or after an initial supplied start date 4
EOMONTH Returns a date that is the last day of the month which is a specified number of months before or after an initial supplied start date 4
HOUR Returns the hour part of a user-supplied time 4
ISOWEEKNUM Returns the ISO week number of the year for a given date 4
MINUTE Returns the minute part of a user-supplied time 4
MONTH Returns the month from a user-supplied date 4
NETWORKDAYS Returns the number of whole networkdays (excluding weekends & holidays), between two supplied dates 4
NETWORKDAYS.INTL Returns the number of whole networkdays (excluding weekends & holidays), between two supplied dates, using parameters to specify weekend days 4
NOW Returns the current date & time 4
SECOND Returns the seconds part of a user-supplied time 4
TIME Returns a time, from a user-supplied hour, minute and second 4
TIMEVALUE Converts a text string showing a time, to a decimal that represents the time in Excel 4
TODAY Returns today's date 4
WEEKDAY Returns an integer representing the day of the week for a supplied date 4
WEEKNUM Returns an integer representing the week number (from 1 to 53) of the year from a user-supplied date 4
WORKDAY Returns a date that is a supplied number of working days (excluding weekends & holidays) ahead of a given start date 4
WORKDAY.INTL Returns a date that is a supplied number of working days (excluding weekends & holidays) ahead of a given start date, using supplied parameters to specify weekend days 5.0
YEAR Returns the year from a user-supplied date 4
YEARFRAC Calculates the fraction of the year represented by the number of whole days between two dates 4

Engineering

Function Description From EPPlus version
BESSELI Calculates the modified Bessel function In(x) 5.2
BESSELJ Calculates the Bessel function Jn(x) 5.2
BESSELK Calculates the modified Bessel function Kn(x) 5.2
BESSELY Calculates the modified Bessel function Yn(x) 5.2
BIN2DEC Converts a binary number to a decimal 5.1
BIN2HEX Converts a binary number to hexadecimal 5.1
BIN2OCT Converts a binary number to octal 5.1
BITAND Returns a Bitwise 'And' of two numbers 5.1
BITLSHIFT Returns a number shifted left by a specified number of bits 5.1
BITOR Returns a Bitwise 'Or' of two numbers 5.1
BITRSHIFT Returns a number shifted right by a specified number of bits 5.1
BITXOR Returns a Bitwise 'Exclusive Or' of two numbers 5.1
CONVERT Calculates the modified Bessel function Yn(x) 5.1
DEC2BIN Converts a decimal number to binary 5.1
DEC2HEX Converts a decimal number to hexadecimal 5.1
DEC2OCT Converts a decimal number to octal 5.1
DELTA Tests whether two supplied numbers are equal 5.1
ERF Returns the error function integrated between two supplied limits 5.2
ERF.PRECISE Returns the complementary error function integrated between a supplied lower limit and infinity 5.2
ERFC Returns the complementary error function integrated between a supplied lower limit and infinity 5.2
ERFC.PRECISE Returns the complementary error function integrated between a supplied lower limit and infinity 5.2
HEX2BIN Converts a hexadecimal number to binary 5.1
HEX2DEC Converts a hexadecimal number to a decimal 5.1
HEX2OCT Converts a hexadecimal number to octal 5.1
OCT2BIN Converts octal number to binary 5.1
OCT2DEC Converts octal number to a decimal 5.1
OCT2HEX Converts octal number to hexadecimal 5.1

Financial

Function Description From EPPlus version
COUPDAYBS Calculates the number of days from the beginning of the coupon period to the settlement date 5.2
COUPDAYS Calculates the number of days in the coupon period that contains the settlement date 5.2
COUPDAYSNC Calculates the number of days from the settlement date to the next coupon date 5.2
COUPNCD Returns the next coupon date after the settlement date 5.2
COUPNUM Returns the number of coupons payable between the settlement date and maturity date 5.2
COUPPCD Returns the previous coupon date, before the settlement date 5.2
CUMIPMT Calculates the cumulative interest paid between two specified periods 5.2
CUMPRINC Calculates the cumulative principal paid on a loan, between two specified periods 5.2
DDB Calculates the depreciation of an asset for a specified period, using the double-declining balance method, or some other user-specified method 5.2
DISC Calculates the discount rate for a security 5.2
DURATION Calculates the Macauley duration of a security with an assumed par value of $100 5.2
EFFECT Calculates the effective annual interest rate from a supplied Nominal interest rate and number of periods 5.2
FV Calculates the future value of an investment with periodic constant payments and a constant interest rate 5.2
FVSCHEDULE Calculates the future value of an initial principal, after applying a series of compound interest rates 5.2
IPMT Calculates the interest payment for a given period of an investment, with periodic constant payments and a constant interest rate 5.2
IRR Calculates the internal rate of return for a series of periodic cash flows 5.2
ISPMT Returns the interest paid during a specified period of an investment 5.2
MIRR Calculates the internal rate of return for a series of periodic cash flows, considering the cost of the investment and the interest on the reinvestment of cash 5.2
NOMINAL Calculates the annual nominal interest rate from a supplied Effective interest rate and number of periods 5.2
NPER Returns the number of periods for an investment with periodic constant payments and a constant interest rate 5.2
NPV Calculates the net present value of an investment, based on a supplied discount rate, and a series of periodic cash flows 5.2
PDURATION Calculates the number of periods required for an investment to reach a specified value 5.2
PMT Calculates the payments required to reduce a loan, from a supplied present value to a specified future value 4
PPMT Calculates the payments required to reduce a loan, from a supplied present value to a specified future value 5.2
PRICE Calculates the price per $100 face value of a security that pays periodic interest 5.2
PV Calculates the present value of an investment (i.e. the total amount that a series of future periodic constant payments is worth now) 5.2
RATE Calculates the interest rate required to pay off a specified amount of a loan, or reach a target amount on an investment over a given period 5.2
RRI Calculates the interest rate required for an investment to grow to a specified future value 5.2
SLN Returns the straight-line depreciation of an asset for one period 5.2
SYD Returns the sum-of-years' digits depreciation of an asset for a specified period 5.2
XIRR Calculates the internal rate of return for a schedule of cash flows occurring at a series of supplied dates 5.2
XNPV Calculates the net present value for a schedule of cash flows occurring at a series of supplied dates 5.2
YIELD Calculates the yield of a security that pays periodic interest 5.2

Information

Function Description From EPPlus version
ERROR.TYPE Tests a supplied value and returns an integer relating to the supplied value's error type 4
ISBLANK Tests if a supplied cell is blank (empty), and if so, returns TRUE; Otherwise, returns FALSE 4
ISERR Tests if an initial supplied value (or expression) returns an error (EXCEPT for the #N/A error) and if so, returns TRUE; Otherwise returns FALSE 4
ISERROR Tests if an initial supplied value (or expression) returns an error and if so, returns TRUE; Otherwise returns FALSE 4
ISEVEN Tests if a supplied number (or expression) is an even number, and if so, returns TRUE; Otherwise, returns FALSE. 4
ISLOGICAL Tests if a supplied value is a logical value, and if so, returns TRUE; Otherwise, returns FALSE 4
ISNA Tests if an initial supplied value (or expression) returns the Excel #N/A error and if so, returns TRUE; Otherwise returns FALSE 4
ISNONTEXT Tests if an initial supplied value (or expression) returns the Excel #N/A error and if so, returns TRUE; Otherwise returns FALSE 4
ISNUMBER Tests if a supplied value is a number, and if so, returns TRUE; Otherwise, returns FALSE. 4
ISODD Tests if a supplied number (or expression) is an odd number, and if so, returns TRUE; Otherwise, returns FALSE. 4
ISTEXT Tests if a supplied value is text, and if so, returns TRUE; Otherwise, returns FALSE 4
N Converts a non-number value to a number, a date to a serial number, the logical value TRUE to 1 and all other values to 0 4
NA Returns the Excel #N/A error 4
TYPE Returns information about the data type of a supplied value 4

Logical

Function Description From EPPlus version
AND Tests a number of user-defined conditions and returns TRUE if ALL of the conditions evaluate to TRUE, or FALSE otherwise 4
FALSE Returns the logical value FALSE 4
IF Tests a user-defined condition and returns one result if the condition is TRUE, and another result if the condition is FALSE 4
IFERROR Tests a user-defined condition and returns one result if the condition is TRUE, and another result if the condition is FALSE 4
IFNA Tests a user-defined condition and returns one result if the condition is TRUE, and another result if the condition is FALSE 4
IFS Tests a user-defined condition and returns one result if the condition is TRUE, and another result if the condition is FALSE 5.0
NOT Returns a logical value that is the opposite of a user supplied logical value or expression (i.e.returns FALSE is the supplied argument is TRUE and returns TRUE if the supplied argument is FALSE) 4
OR Returns the logical value FALSE 4
SWITCH Compares a number of supplied values to a supplied test expression and returns a result corresponding to the first value that matches the test expression. 5.0
TRUE Returns the logical value TRUE 4

Lookup and reference

Function Description From EPPlus version
ADDRESS Returns a reference, in text format, for a supplied row and column number 4
CHOOSE Returns one of a list of values, depending on the value of a supplied index number 4
COLUMN Returns the column number of a supplied range, or of the current cell 4
COLUMNS Returns the number of columns in a supplied range 4
HLOOKUP Looks up a supplied value in the first row of a table, and returns the corresponding value from another row 4
INDEX Returns a reference to a cell (or range of cells) for requested rows and columns within a supplied range 4
INDIRECT Returns a cell or range reference that is represented by a supplied text string 4
LOOKUP Searches for a specific value in one data vector, and returns a value from the corresponding position of a second data vector 4
MATCH Finds the relative position of a value in a supplied array 4
OFFSET Returns a reference to a range of cells that is a specified number of rows and columns from an initial supplied range 4
ROW Returns the row number of a supplied range, or of the current cell 4
ROWS Returns the number of rows in a supplied range 4
VLOOKUP Looks up a supplied value in the first column of a table, and returns the corresponding value from another column 4

Math and trig

Function Description From EPPlus version
ABS Returns the absolute value (i.e. the modulus) of a supplied number 4
ACOS Returns the Arccosine of a number 4
ACOSH Returns the inverse hyperbolic cosine of a number 4
ACOT Returns the inverse hyperbolic cosine of a number 5.1
ACOTH Returns the hyperbolic arccotangent of a number 5.1
ASIN Returns the Arcsine of a number 5.1
ASINH Returns the Inverse Hyperbolic Sine of a number 4
ATAN Returns the Inverse Hyperbolic Sine of a number 4
ATAN2 Returns the Arctangent of a given pair of x and y coordinates 4
ATANH Returns the Arctangent of a given pair of x and y coordinates 4
CEILING Rounds a number away from zero (i.e. rounds a positive number up and a negative number down), to a multiple of significance 4
CEILING.MATH Rounds a number up to the nearest integer or to the nearest multiple of significance 5.1
CEILING.PRECISE Rounds a number up, regardless of the sign of the number, to a multiple of significance 5.1
COMBIN Returns the number of combinations (without repititions) for a given number of objects 5.1
COMBINA Returns the number of combinations (with repetitions) for a given number of items 5.1
COS Returns the Cosine of a given angle 4
COSH Returns the hyperbolic cosine of a number 4
COT Returns the cotangent of an angle 5.1
COTH Returns the hyperbolic cotangent of an angle 5.1
CSC Returns the cosecant of an angle 5.1
CSCH Returns the hyperbolic cosecant of an angle 5.1
DEGREES Converts Radians to Degrees 4
EVEN Rounds a number away from zero (i.e. rounds a positive number up and a negative number down), to the next even number 5.0
EXP Returns e raised to a given power 4
FACT Returns the Factorial of a given number 4
FACTDOUBLE Returns the Double Factorial of a given number 5.1
FLOOR Rounds a number towards zero, (i.e. rounds a positive number down and a negative number up), to a multiple of significance 4
FLOOR.MATH Rounds a number down, to the nearest integer or to the nearest multiple of significance 5.1
FLOOR.PRECISE Rounds a number down, regardless of the sign of the number, to a multiple of significance 5.1
GCD Returns the Greatest Common Divisor of two or more supplied numbers 5.1
INT Rounds a number down to the next integer 4
ISO.CEILING Rounds a number up, regardless of the sign of the number, to a multiple of significance. 5.1
LN Returns the natural logarithm of a given number 4
LOG Returns the logarithm of a given number, to a specified base 4
LOG10 Returns the base 10 logarithm of a given number 4
MOD Returns the remainder from a division between two supplied numbers 4
MROUND Rounds a number up or down, to the nearest multiple of significance 5.1
ODD Rounds a number away from zero (i.e. rounds a positive number up and a negative number down), to the next odd number 5.0
PI Returns the constant value of pi 4
POWER Returns the result of a given number raised to a supplied power 4
PRODUCT Returns the product of a supplied list of numbers 4
QUOTIENT Returns the integer portion of a division between two supplied numbers 4
RADIANS Converts Degrees to Radians 5.1
RAND Returns a random number between 0 and 1 4
RANDBETWEEN Returns a random number between two given integers 4
ROMAN Returns a text string depicting the roman numeral for a given number 5.1
ROUND Rounds a number up or down, to a given number of digits 4
ROUNDDOWN Rounds a number towards zero, (i.e. rounds a positive number down and a negative number up), to a given number of digits 4
ROUNDUP Rounds a number away from zero (i.e. rounds a positive number up and a negative number down), to a given number of digits 4
SEC Returns the secant of an angle 5.1
SECH Returns the hyperbolic secant of an angle 5.1
SERIESSUM Returns the sum of a power series 5.1
SIGN Returns the sign (+1, -1 or 0) of a supplied number 4
SIN Returns the Sine of a given angle 4
SINH Returns the Hyperbolic Sine of a number 4
SQRT Returns the positive square root of a given number 4
SQRTPI Returns the square root of a supplied number multiplied by pi 4
SUBTOTAL Performs a specified calculation (e.g. the sum, product, average, etc.) for a supplied set of values 4
SUM Returns the sum of a supplied list of numbers 4
SUMIF Adds the cells in a supplied range, that satisfy a given criteria 4
SUMIFS Adds the cells in a supplied range, that satisfy multiple criteria 4
SUMPRODUCT Returns the sum of the products of corresponding values in two or more supplied arrays 4
SUMSQ Returns the sum of the squares of a supplied list of numbers 4
SUMX2MY2 Returns the sum of the difference of squares of corresponding values in two supplied arrays 5.1
SUMX2PY2 Returns the sum of the sum of squares of corresponding values in two supplied arrays 5.1
SUMXMY2 Returns the sum of squares of differences of corresponding values in two supplied arrays 5.1
TAN Returns the Tangent of a given angle 4
TANH Returns the Hyperbolic Tangent of a given number 4
TRUNC Truncates a number towards zero (i.e. rounds a positive number down and a negative number up), to the next integer. 4

Statistical

Function Description From EPPlus version
AVERAGE Returns the Average of a list of supplied numbers 4
AVERAGEA Returns the Average of a list of supplied numbers, counting text and the logical value FALSE as the value 0 and counting the logical value TRUE as the value 1 4
AVERAGEIF Calculates the Average of the cells in a supplied range, that satisfy a given criteria 4
AVERAGEIFS Calculates the Average of the cells in a supplied range, that satisfy multiple criteria 4
COUNT Returns the number of numerical values in a supplied set of cells or values 4
COUNTA Returns the number of non-blanks in a supplied set of cells or values 4
COUNTBLANK Returns the number of blank cells in a supplied range 4
COUNTIF Returns the number of cells (of a supplied range), that satisfy a given criteria 4
COUNTIFS Returns the number of cells (of a supplied range), that satisfy a set of given criteria 4
LARGE Returns the Kth LARGEST value from a list of supplied numbers, for a given value K 4
LCM Returns the Least Common Multiple of two or more supplied numbers 5.1
MAX Returns the largest value from a list of supplied numbers 4
MAXA Returns the largest value from a list of supplied values, counting text and the logical value FALSE as the value 0 and counting the logical value TRUE as the value 1 4
MEDIAN Returns the largest value from a list of supplied numbers 4
MIN Returns the smallest value from a list of supplied numbers 4
MINA Returns the smallest value from a list of supplied values, counting text and the logical value FALSE as the value 0 and counting the logical value TRUE as the value 1 4
MODE Returns the Mode (the most frequently occurring value) of a list of supplied numbers 5.2
MODE.SNGL Returns the Mode (the most frequently occurring value) of a list of supplied numbers 5.2
PERCENTILE Returns the K'th percentile of values in a supplied range, where K is in the range 0 - 1 (inclusive) 5.2
PERCENTILE.INC Returns the K'th percentile of values in a supplied range, where K is in the range 0 - 1 (inclusive) 5.2
PERCENTRANK The Excel Percentrank function calculates the relative position, between 0 and 1 (inclusive), of a specified value within a supplied array. 5.2
PERCENTRANK.INC The Excel Percentrank.Inc function calculates the relative position, between 0 and 1 (inclusive), of a specified value within a supplied array. 5.2
RANK Returns the statistical rank of a given value, within a supplied array of values 4
RANK.AVG Returns the statistical rank of a given value, within a supplied array of values (if more than one value has same rank, the average rank is returned) 4
RANK.EQ Returns the Mode (the most frequently occurring value) of a list of supplied numbers (if more than one value has same rank, the top rank of that set is returned) 4
SMALL Returns the Kth SMALLEST value from a list of supplied numbers, for a given value K 4
STDEV Returns the standard deviation of a supplied set of values (which represent a sample of a population) 4
STDEV.P Returns the standard deviation of a supplied set of values (which represent an entire population) 4
STDEV.S Returns the standard deviation of a supplied set of values (which represent a sample of a population) 4
STDEVP Returns the standard deviation of a supplied set of values (which represent an entire population) 4
VAR Returns the variance of a supplied set of values (which represent a sample of a population) 4
VAR.P Returns the variance of a supplied set of values (which represent an entire population) 5.2
VAR.S Returns the variance of a supplied set of values (which represent a sample of a population) 5.2
VARP Returns the variance of a supplied set of values (which represent an entire population) 4

Text

Function Description From EPPlus version
CHAR Returns the character that corresponds to a supplied numeric value 4
CLEAN Removes all non-printable characters from a supplied text string 5.0
CONCAT Joins together two or more text strings 5.0
CONCATENATE Joins together two or more text strings 4
EXACT Tests if two supplied text strings are exactly the same and if so, returns TRUE; Otherwise, returns FALSE. (case-sensitive) 4
FIND Tests if two supplied text strings are exactly the same and if so, returns TRUE; Otherwise, returns FALSE. (case-sensitive) 4
FIXED Rounds a supplied number to a specified number of decimal places, and then converts this into text 4
HYPERLINK Creates a hyperlink to a document in a supplied location. 4
LEFT Returns a specified number of characters from the start of a supplied text string 4
LEN Returns the length of a supplied text string 4
LOWER Converts all characters in a supplied text string to lower case 4
MID Returns a specified number of characters from the middle of a supplied text string 4
NUMBERVALUE Converts text to a number, in a locale-independent way 5.0
PROPER Converts all characters in a supplied text string to proper case (i.e. letters that do not follow another letter are upper case and all other characters are lower case) 4
REPLACE Replaces all or part of a text string with another string (from a user supplied position) 4
REPT Returns a string consisting of a supplied text string, repeated a specified number of times 4
RIGHT Returns a specified number of characters from the end of a supplied text string 4
SEARCH Returns the position of a supplied character or text string from within a supplied text string (non-case-sensitive) 4
SUBSTITUTE Substitutes all occurrences of a search text string, within an original text string, with the supplied replacement text 4
T Tests whether a supplied value is text and if so, returns the supplied text; If not, returns an empty text string. 4
TEXT Converts a supplied value into text, using a user-specified format 4
TEXTJOIN Joins together two or more text strings, separated by a delimiter 5.2
TRIM Removes duplicate spaces, and spaces at the start and end of a text string 4
UNICHAR Returns the Unicode character that is referenced by the given numeric value 5.0
UNICODE Returns the number (code point) corresponding to the first character of a supplied text string 5.0
UPPER Converts all characters in a supplied text string to upper case 4
VALUE Converts a text string into a numeric value 4

EPPlus wiki

Versions

Worksheet & Ranges

Styling

Import/Export data

Formulas and filters

Charts & Drawing objects

Tables & Pivot Tables

VBA & Protection

Clone this wiki locally