SAP EVAL_FORMULA_EXT Function Module for









EVAL_FORMULA_EXT is a standard eval formula ext SAP function module available within SAP R/3 or S/4 Hana systems, depending on your version and release level. It is used to perform a specific ABAP function and below is the pattern details, showing its interface including any import and export parameters, exceptions etc. there is also a full "cut and paste" ABAP pattern code example, along with implementation ABAP coding, documentation and contribution comments specific to this or related objects.


See here to view full function module documentation and code listing for eval formula ext FM, simply by entering the name EVAL_FORMULA_EXT into the relevant SAP transaction such as SE37 or SE38.

Function Group: CALC_EXT
Program Name: SAPLCALC_EXT
Main Program: SAPLCALC_EXT
Appliation area:
Release date: N/A
Mode(Normal, Remote etc): Normal Function Module
Update:



Function EVAL_FORMULA_EXT pattern details

In-order to call this FM within your sap programs, simply using the below ABAP pattern details to trigger the function call...or see the full ABAP code listing at the end of this article. You can simply cut and paste this code into your ABAP progrom as it is, including variable declarations.
CALL FUNCTION 'EVAL_FORMULA_EXT'"
EXPORTING
* DEGREES = ' ' "
FORMULA = "
* PROGRAM = ' ' "
* ROUTINE = ' ' "
* UNIT_OF_MEASURE = ' ' "
* NO_EXISTENCE_CHECK = ' ' "

IMPORTING
VALUE = "

EXCEPTIONS
DIVISION_BY_ZERO = 1 MISSING_PARAMETER = 10 EXP_ERROR = 2 FORMULA_TABLE_NOT_VALID = 3 INVALID_EXPRESSION = 4 INVALID_VALUE = 5 LOG_ERROR = 6 PARAMETER_ERROR = 7 SQRT_ERROR = 8 UNITS_NOT_VALID = 9
.



IMPORTING Parameters details for EVAL_FORMULA_EXT

DEGREES -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

FORMULA -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

PROGRAM -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

ROUTINE -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

UNIT_OF_MEASURE -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

NO_EXISTENCE_CHECK -

Data type:
Default: SPACE
Optional: Yes
Call by Reference: No ( called with pass by value option)

EXPORTING Parameters details for EVAL_FORMULA_EXT

VALUE -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

EXCEPTIONS details

DIVISION_BY_ZERO -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

MISSING_PARAMETER -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

EXP_ERROR -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

FORMULA_TABLE_NOT_VALID -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

INVALID_EXPRESSION -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

INVALID_VALUE -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

LOG_ERROR -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

PARAMETER_ERROR -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

SQRT_ERROR -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

UNITS_NOT_VALID -

Data type:
Optional: No
Call by Reference: No ( called with pass by value option)

Copy and paste ABAP code example for EVAL_FORMULA_EXT Function Module

The ABAP code below is a full code listing to execute function module POPUP_TO_CONFIRM including all data declarations. The code uses the original data declarations rather than the latest in-line data DECLARATION SYNTAX but I have included an ABAP code snippet at the end to show how declarations would look using the newer method of declaring data variables on the fly. This will allow you to compare and fully understand the new inline method. Please note some of the newer syntax such as the @DATA is not available until a later 4.70 service pack (SP8), which i why i have stuck to the origianl for this example.

DATA:
lv_value  TYPE STRING, "   
lv_degrees  TYPE STRING, "   SPACE
lv_division_by_zero  TYPE STRING, "   
lv_missing_parameter  TYPE STRING, "   
lv_formula  TYPE STRING, "   
lv_exp_error  TYPE STRING, "   
lv_program  TYPE STRING, "   SPACE
lv_formula_table_not_valid  TYPE STRING, "   
lv_routine  TYPE STRING, "   SPACE
lv_invalid_expression  TYPE STRING, "   
lv_invalid_value  TYPE STRING, "   
lv_unit_of_measure  TYPE STRING, "   SPACE
lv_log_error  TYPE STRING, "   
lv_no_existence_check  TYPE STRING, "   SPACE
lv_parameter_error  TYPE STRING, "   
lv_sqrt_error  TYPE STRING, "   
lv_units_not_valid  TYPE STRING. "   

  CALL FUNCTION 'EVAL_FORMULA_EXT'  "
    EXPORTING
         DEGREES = lv_degrees
         FORMULA = lv_formula
         PROGRAM = lv_program
         ROUTINE = lv_routine
         UNIT_OF_MEASURE = lv_unit_of_measure
         NO_EXISTENCE_CHECK = lv_no_existence_check
    IMPORTING
         VALUE = lv_value
    EXCEPTIONS
        DIVISION_BY_ZERO = 1
        MISSING_PARAMETER = 10
        EXP_ERROR = 2
        FORMULA_TABLE_NOT_VALID = 3
        INVALID_EXPRESSION = 4
        INVALID_VALUE = 5
        LOG_ERROR = 6
        PARAMETER_ERROR = 7
        SQRT_ERROR = 8
        UNITS_NOT_VALID = 9
. " EVAL_FORMULA_EXT




ABAP code using 7.40 inline data declarations to call FM EVAL_FORMULA_EXT

The below ABAP code uses the newer in-line data declarations. This allows you to see the coding differences/benefits of the later inline syntax. Please note some of the newer syntax below, such as the @DATA is not available until 4.70 EHP 8.

 
DATA(ld_degrees) = ' '.
 
 
 
 
 
DATA(ld_program) = ' '.
 
 
DATA(ld_routine) = ' '.
 
 
 
DATA(ld_unit_of_measure) = ' '.
 
 
DATA(ld_no_existence_check) = ' '.
 
 
 
 


Search for further information about these or an SAP related objects



Comments on this SAP object

What made you want to lookup this SAP object? Please tell us what you were looking for and anything you would like to be included on this page!