Business Functions Blog
Version 1.67 | Wed 01 Jan 25 |
Just a maintenance update, fixed the VBA Range Manager , a utility which wasn't working. |
Version 1.66 | Fri 22 Dec 23 |
Mainly a recompile with latest Microsoft C++ 17.8. Fixed a bug in the menu dropdown for Daycount -slightly cosmetic change didn't change operation of the library per se - but was confusing. |
Version 1.65 | Tue 11 Apr 23 |
Mainly a recompile with latest Microsoft C++. The strange but harmless @ symbols that appeared in example files have been removed. |
Excels Dynamic Array Formula and the Mysterious @ sign | Wed 23 Mar 22 |
Recently (I'm not sure when), Microsoft made a very big change to formula functionality with Dynamic Array Formulas:
Microsoft Link
Link
Dynamic array formulas enable a function to "spill" its results to adjacent cells, if that function returns more than one value. This gave Microsoft a problem - what to do with 3rd party functions where Excel doesn't know if it returns multiple values? Their answer is the '@' prefix , which may appear A LOT on saved workbooks that you open in a newish version of Excel. Do not worry! The sign is just telling Excel "if this function returns multiple values, just use the first one". That is fine. You can also safely REMOVE the @ sign for Business Functions.
As you know, Business Functions has used Excels traditional array function methodology for many years. This had a slightly cumbersome "Ctrl-Enter" method of inputting and editing. THIS STILL WORKS FINE. The Business Functions method works great because it is still the native Excel method and it is quite robust because it determines (it doesn't guess) whether its an array function or a normal (single cell) function. It KNOWS if the function call is coming from multiple cells, and it calls a completely different function that returns the multiple values.
The new Microsoft method may take some time to adjust to, personally I am nervous. It is designed to be very user friendly but doesn't feel all that rigorous to me. A single cell function call that can spill sideways and downwards? It feels a bit like cheating! Anyway, if it stands the test of time it may mean that Business Functions array functions are adapted. But for now, the Business Functions way is tried and tested and robust. It has the by product that its hard to mess up an array formula once its programmed in, which I quite like.
Anyway, the takeaway is that the @ sign is to cope with a change Microsoft made to formula behaviour, and if mysteriously appears, it means Excel was in 2 minds what your formula does and is playing safe, and it most cases you can just remove it. |
Version 1.63 | Fri 11 Feb 22 |
Maintenance Release. After taking the Regular Expression functions out in version 1.62, we actually put them back in this release because they have recently been incorporated into the basic C++ library. So I upgraded to latest version of C++ (20) and completed the removal of Boost library dependencies that didn't get sorted out in 1.62. Also, the help file has a listing of the source code in C++ for the curious. It won't explain everything but may help in understanding. |