Using LET function in Excel with formula examples

This tutorial is introducing the new Excel LET function that makes intricate formulas look more comprehensible and calculate faster.

If you work with lengthy formulas in Excel, then you are certainly familiar with the idea of named ranges that make complex formulas easier to read. And now, Microsoft is making a step further and allows assigning names to calculations and values directly in a formula. If your formula uses the same expression several times, you can let Excel calculate it just once, store the result inside a formula and reuse as many times as needed. Sounds exciting, isn't it?

Excel LET function

The Excel LET function allows you to assign names to calculation results and define variables inside a formula, so that the formula looks clearer and works faster.

Essentially, the concept is the same as naming cells, ranges and formulas in the Name Manager. What makes the LET function different is that the declared names only exist in the scope of a given formula and nowhere else.

Syntax

LET has the following syntax and arguments:

LET (name1, name_value1, [name2], [name_value2], …, calculation)

Where:

  • Name1 (required) - the first name to assign. It must begin with a letter.
  • Name_value1 (required) - the value or calculation assigned to name1.
  • Name2 / name_value2 (optional) - the second name and value.
  • Calculation (required) - a calculation that uses assigned names and values.

The function can process up to 126 name/value pairs.

Note. Microsoft uses a slightly different syntax notation:

LET(name1, name_value1, calculation_or_name2, [name_value2, calculation_or_name3…])

I personally find it a little confusing, so I put it in a more customary form. Basically, they talk about the same thing but in different ways.

Availability

The LET function is only available in these versions of Excel:

  • Excel 365 (for Windows and Mac)
  • Excel 2021 (for Windows and Mac)
  • Excel for the web

Basic LET formula

If you do not have a clear understanding of the function yet, an example of the LET formula in its simplest form will help bring the essentials into focus.

Consider this simple expression: x+y. Here, we have 2 variables, x and y. Let's assign the value 2 to x, the value 5 to y and multiply one by the other:

=LET(x, 2, y, 5, x*y)

Enter this formula in a cell, and it will return 10 as the result.
Excel LET function

Instead of values, the variables can be assigned to cell references, say x to B2 and y to B3:

=LET(x,B2, y, B3, x * y)
Basic LET formula

To ease building a formula, the already declared names appear in the intellisense drop down list, just like the names defined in the name manager.
Writing a LET formula in Excel

Looking at the above formula you may be wondering, what's the point in over-complicating things? Why not simply put:

=B2*B3

In this particular case, a normal multiplication is of course simpler. The purpose is to clarify the concept. When it comes to more complex formulas with repeated calculations, the LET function takes on a whole new degree of usefulness as demonstrated in the further examples.

Advantages

If you still doubt that LET will be a worthy addition to your Excel toolbox, then consider these benefits:

Simplified formulas. Giving descriptive names to variables and intermediate calculations makes it easier to understand what the formula is actually doing. You no longer need to figure out the inner logic of each specific expression or reference in a formula.

Faster calculations. When the same expression is repeated in a formula multiple times, Excel calculates it multiple times. When the expression is referred by name, Excel calculates it only once. As the result, a whole worksheet recalculates much faster. This positive effect on performance is especially noticeable in case of long formulas and huge data sets.

Easy maintenance. Using names for repeated calculations not only makes formulas more compact but also easier to update. When adjustments are needed, you make just a single change instead of updating the same expressions multiple times, thus saving time and reducing a change of human errors.

Usage notes

To shorten the learning curve and prevent common errors, please follow these simple guidelines:

  • A LET formula should have an odd number of arguments - one or several name/value pairs and a calculation. The last argument must always be a calculation that returns the final result.
  • When assigning names in your LET formulas, ensure they comply with Excel's naming conventions. This means names should not include spaces or punctuation marks, must not conflict with cell references, etc.
  • For clarity, avoid using names that are already used in the Name Manager. If the same name is assigned inside LET and defined in the name manager, the name manager version will be ignored.
  • The names declared within a LET formula are only applicable within the scope of that formula itself.

How to use LET function in Excel - formula examples

And now, it's time to look at more realistic use cases and reveal the whole power of the new function.

Example 1. LET formula to reduce repeated calculations

When writing multi-level formulas, it often happens that the same expression or calculation is used more than once. A typical example is nested IF statements. In this context, let's see how LET can simplify things.

Supposing you have the results of student exams in three different subjects (columns B, C and D). You want to find an average for each student and grade it as shown in the table on the right:
The source data

The AVERAGE function can easily compute an arithmetic mean for each row:

AVERAGE(B2:D2)

And then, you build a nested IF statement based on the above criteria.

=IF(AVERAGE(B2:D2)>249, "Excellent", IF(AVERAGE(B2:D2)>=200, "Good", IF(AVERAGE(B2:D2)>150, "Satisfactory", "Poor")))

The problem is the same AVERAGE function is repeated three times. Well, maybe not really a problem, but an unnecessary complication that forces Excel to perform the same calculation thrice.

To optimize the formula, we can assign a name to the AVERAGE function (say, avg) and replace the function with this "local" name. This way, an average is calculated just once helping the formula run faster:

=LET(avg, AVERAGE(B2:D2), IF(avg>249, "Excellent", IF(avg>=200, "Good", IF(avg>150, "Satisfactory", "Poor"))))

Enter the formula in E2, drag it down through E10, and you'll get this result:
LET formula with nested IFs

Imagine you add one more exam (column E) to the source table. Naturally, you wish to include that in the average. Without LET, you'd have to perform this adjustment in the logical test of every IF function. Being a human being, you might overlook something and fail to update all the references correctly. With LET, you make just a single change:

=LET(avg, AVERAGE(B2:E2), IF(avg>249, "Excellent", IF(avg>=200, "Good", IF(avg>150, "Satisfactory", "Poor"))))
Updating a LET formula

Example 2. LET with multiple names

Here's another example showing how the LET function can ease the creation of complex formulas.

Let's say you have a list of full names (column A) from which you wish to extract middle names. The below formula does the job perfectly, but at first sight its logic is quite obscure:

=MID(A2, SEARCH(" ", A2) + 1, SEARCH(" ", A2, SEARCH(" ", A2) +1) - SEARCH(" ", A2) - 1)

To provide some meaningful context to yourself and other users, you can define a couple of names such as:

  • full_name - A2
  • space - SEARCH(" ", full_name)

Obviously, cell A2 contains a full name that needs to be split, and the SEARCH function returns the position of the first space character in the name.

And then, we replace the cell reference and the SEARCH function with the declared names.

=LET(full_name, A2, space, SEARCH(" ", full_name), MID(full_name, space + 1, SEARCH(" ", full_name, space + 1) - space - 1))

If you are familiar with the MID syntax, the formula becomes much easier to comprehend:

To the position of the first space, you add 1 to start the extraction from the next character (space+1). To get the length of the middle name (i.e. how many characters to extract from the full name), you determine the position of the second space by nesting one SEARCH function into another, then find the difference between the positions of the two spaces and subtract 1 from the result to eliminate a trailing space (SEARCH(" ", full_name, space+1) - space -1)).

For better readability, you can wrap the names and calculation onto separate lines like this:
LET formula with multiple names

Example 3. LET function with dynamic arrays

In the previous examples, the LET function operated on a single cell, and we copied the formula to the below cells. However, LET can also accept arrays as input and produce arrays as output. This is possible due to Excel 365's new calculation engine and dynamic arrays.

From the below table, suppose you want to get a list of exams that are to be taken in the next n days, not including today. This can be done by using the FILTER function with multiple criteria:

FILTER(data, (dates>today) * (dates<=today+n), "No results")

All you need to do is to define the corresponding names:

  • data - A2:C19
  • dates - C2:C19
  • today - TODAY()
  • n - F3

After that, put the names and FILTER formula inside LET:

=LET(data, A2:C19, dates, C2:C19, today, TODAY(), n, F3, FILTER(data, (dates>today) * (dates<=today+n), "No results"))

The result is an array of records matching the specified criteria:
Using LET function with dynamic arrays

Excel LET function not working

If you cannot find the LET function in your Excel or your formula results in error, that may happen because of the following reasons:

There is no LET function in my Excel

The LET function is only available in these Excel versions. The function is not backward compatible and won't appear in earlier Excel versions.

#NAME? error

As there's a very slim chance that someone may misprint the function's name, the problem is most likely with assigned names. Please make sure you've declared each name used in the calculation and all of the names are spelled correctly.

Invalid names

If you encounter a "there's a problem with this formula" error message while inputting a LET formula, it could be due to improperly defined names. For instance, names like "Abc1" or "Fun1" won't be accepted since they coincide with cell references ABC1 or FUN1. This clash leads to internal conflicts, causing Excel to display an error. To avoid such errors, ensure that names are unique and compliant with Excel naming rules.

That's how you can simplify and speed up your calculations with the help of the LET function. I thank you for reading and hope to see you on our blog next week!

Practice workbook for download

Excel LET formula examples (.xlsx file)

8 comments

  1. Could someone please comment why seq is not a range? Ultimately, I like to mark blocks of trues & falses with sequential numbers that incrementally goes from 1 to n. There are more calculation beyond this but I just like to get pass this hump 1st. Thank you.
    =LET(
    range, A2:A10,
    med, MEDIAN(range),
    tf, range > med,
    seq, IF(ROW(A2:A10)=ROW(A2), 1, IF(tfOFFSET(tf,-1,0), OFFSET(seq,-1,0)+1, OFFSET(seq,-1,0))),
    seq
    )

    1. Hello Kyle!
      The provided Excel formula generates a sequence of numbers that increases whenever a block of "TRUE" values is encountered in the tf array. However, this formula has some issues:
      tfOFFSET(tf,-1,0): This part of the formula seems to be incorrect. The OFFSET function requires a valid reference as its first argument. Using tfOFFSET directly is likely to cause an error.
      OFFSET(seq,-1,0): This part of the formula also has a potential issue. If you’re not careful with how you define or initialize your sequence, using OFFSET(seq,-1,0) can cause some unexpected results or errors.
      Please try the following formula:

      =LET(
      range, A2:A10,
      med, MEDIAN(range),
      tf, range > med,
      seq, SCAN(0, tf, LAMBDA(a, b, IF(b, a+1, 1))),
      seq
      )

      LET function helps define and reuse intermediate values in formulas, making them more readable and maintainable.
      range, A2:A10: This defines the range of cells containing the data.
      med, MEDIAN(range): This calculates the median of the data in the range.
      tf, range > med: This creates an array of TRUE/FALSE values based on whether each value in the range is greater than the median.
      seq, SCAN(0, tf, LAMBDA(a, b, IF(b, a+1, 1))): This is the core of the formula.
      SCAN is a powerful function that iterates through an array and accumulates a result.
      0 is the initial value of the sequence.
      tf is the array of TRUE/FALSE values.
      LAMBDA(a, b, IF(b, a+1, 1)) is the lambda function that defines how the sequence is updated:
      If the current value of tf is TRUE (b is TRUE), the previous value of the sequence (a) is incremented by 1.
      If the current value of tf is FALSE (b is FALSE), the sequence is reset to 1.
      We have a special tutorial on LAMBDA function. Please see: Excel LAMBDA function: how to write and use.
      This formula assigns sequential numbers to blocks of TRUE values.

  2. Oz,

    Thank you for the post. The concept of joining multiple arrays or ranges would be very powerful and a concept that I have researched previously and continue to monitor for in Excel. However, I have yet to find a functional example of this. I attempted to run your example function and after correcting for quotes in the function received the following results:

    "A year consists of 1 months. Of which, only 1 hot months, where the hottest among them are: Jun, Jul, Aug. allM is an error = TRUE"

    Anything I attempt to run on coldM, hotM, or allM results in #VALUE for the function indicating that the array is an error as noted above and in the formula below.

    Here is my formula:
    =LET(
    autumnM, {"Sep","Nov","Oct"},
    winterM, {"Dec","Jan","Feb"},
    springM, {"Mar","Apr","May"},
    summerM, {"Jun","Jul","Aug"},

    coldM, autumnM:winterM,
    hotM, springM:summerM,

    allM, coldM:hotM,

    CONCATENATE("A year consists of ", COUNTA(allM), " months. Of which, only ", COUNTA(hotM), " hot months, where the hottest among them are: ", TEXTJOIN(", ", TRUE, summerM), ". allM is an error = ", ISERROR(allM)))

    1. Hello!
      You cannot concatenate arrays the way you are trying to do so. Here is an example of concatenating two arrays -

      =LET(
      b, {"Sep";"Nov";"Oct"},
      a, {"Jun";"Jul";"Aug"},
      s, SEQUENCE(ROWS(a) + ROWS(b)),
      IF(s > ROWS(a),
      INDEX(b, s - ROWS(a)),
      INDEX(a, s)
      ))

  3. Another interesting thing to update and mention is that, once a name was defined with its value (any type of value), each of the following names-values pairs we assign, can immediately start relating to and using it, as you can witness yourself in the parallel "LET function" article of Microsoft's ("Example 2" at the end):
    https://support.microsoft.com/en-us/office/let-function-34842dd8-b92b-4d3f-b325-b8b8f9908999

    So, names can be nested, to give shorter and simpler access to any granular part of them!

    --------------------
    For example, months of the year (by Northern Hemisphere perspective):

    =LET(
    autumnM , {Sep, Nov, Oct},
    winterM, {Dec, Jan, Feb},
    springM, {Mar, Apr, May},
    summerM, {Jun, Jul, Aug},

    coldM, autumnM:winterM,
    hotM, springM:summerM,

    allM, coldM:hotM,

    CONCATENATE("A year consists of ", COUNTA(allM), " months. Of which, only ", COUNTA(hotM), " hot months, where the hottest among them are: ", TEXTJOIN(", ", TRUE, summerM), "."))

    (Result: "A year consists of 12 months. Of which, only 6 hot months, where the hottest among them are: Jun, Jul, Aug.")

  4. I want to list, in a single column, just the unique names of individuals that appear in an array 4 columns wide by any number of rows deep. I'm thinking if I built a LET formula that allows iteration through the array one cell at a time, place it in a LAMBDA, and wrap it all in UNIQUE, I can make this happen. Can't quite figure out how to build the LET function to achieve this. Can you point me in the right direction?

  5. Excellent explanation! I came across this while searching for more info on using LET after seeing it used in a formula to reverse comma separated strings in a cell. It works well, but I was having a hard time figuring out all the various pieces. This helped tremendously in understanding how it's supposed to work and some of the ways it can be leveraged.

    I've got several spreadsheets with tons of complex formulas that really tax my system (and patience) that I'll be looking at to see where I can simplify and hopefully speed up calculations.

  6. How to fix a cell if you get "value" after creating a formula eg 3*5="value"

Post a comment



Thank you for your comment!
When posting a question, please be very clear and concise. This will help us provide a quick and relevant solution to
your query. We cannot guarantee that we will answer every question, but we'll do our best :)