1. Open the Visual Basic Editor and click Insert, Module.
Create a function called MYFUNCTION which returns the sum of the selected cell and the cell below this cell.
2. Add the following code lines:
Function MYFUNCTION(cell As Range)
MYFUNCTION = cell.Value + cell.Offset(1, 0).Value
End Function
3. Now you can use this function, just like any other Excel function.
data:image/s3,"s3://crabby-images/67aa4/67aa4b028d5f17f2b1d6317795051aa580111613" alt=""
4. This is a non-volatile function. Non-volatile functions are only recalculated when any of the function's arguments change. Change the value of cell B2 to 8.
data:image/s3,"s3://crabby-images/08bff/08bff7bd8c22b432ab44b16036677b2dcf0e87e1" alt=""
5. Now change the value of cell B3 to 11.
data:image/s3,"s3://crabby-images/5983e/5983eb24477820779c83322cfcf9ecf925e33a5e" alt=""
Explanation: the non-volatile function is not recalculated when any other cell on the sheet changes.
6. Update the function as follows to make the function volatile:
Function MYFUNCTION(cell As Range)7. Change the value of cell B3 to 12.
Application.Volatile
MYFUNCTION = cell.Value + cell.Offset(1, 0).Value
End Function
Result:
data:image/s3,"s3://crabby-images/97d93/97d93ab2154bbad2fcdc60c5757aa3bf583ca9a5" alt=""
Note: you need to enter the function again to make it volatile (or refresh it by placing your cursor in the formula bar and pressing enter)..