<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>LET関数 &#8211; biz-tactics</title>
	<atom:link href="https://mashukabu.com/tag/let%e9%96%a2%e6%95%b0/feed/" rel="self" type="application/rss+xml" />
	<link>https://mashukabu.com</link>
	<description></description>
	<lastBuildDate>Tue, 26 May 2026 10:47:12 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>

<image>
	<url>https://mashukabu.com/wp-content/uploads/2022/04/cropped-site-icon-32x32.png</url>
	<title>LET関数 &#8211; biz-tactics</title>
	<link>https://mashukabu.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>ExcelのLET・LAMBDA関数の使い方｜数式を自分の関数に変える方法</title>
		<link>https://mashukabu.com/excel-let-lambda-function-guide/</link>
					<comments>https://mashukabu.com/excel-let-lambda-function-guide/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 16 May 2026 23:15:08 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[LAMBDA関数]]></category>
		<category><![CDATA[LET関数]]></category>
		<category><![CDATA[Microsoft 365]]></category>
		<category><![CDATA[カスタム関数]]></category>
		<category><![CDATA[名前定義]]></category>
		<category><![CDATA[数式整理]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=6825</guid>

					<description><![CDATA[ExcelのLET関数とLAMBDA関数の使い方を実務例8パターンで解説。変数定義で数式を整理するLETと、VBA不要でカスタム関数を自作できるLAMBDAを組み合わせれば、数式のメンテナンスコストが大幅に下がります。FAQ・エラー対処付き。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">「このVLOOKUPの数式、ネストが深すぎて自分でも何を書いたか分からない…」。Excelで複雑な数式を扱う方なら、一度はそんな経験があるのではないでしょうか。</p>



<p class="wp-block-paragraph">同じ計算式を複数のセルや別のシートにコピペした後、参照範囲を1か所だけ変えたいとき。気づくと10か所も同じ修正を繰り返し、1つでも直し忘れると <code>#N/A</code> の嵐です。VBAでカスタム関数を作れば解決するとは分かっていても、「マクロは怖い」「セキュリティ警告が嫌だ」と踏み切れない方も多いはずです。</p>



<p class="wp-block-paragraph">そこで本記事では、<strong>LET関数</strong> と <strong>LAMBDA関数</strong> の使い方を解説します。この2つを使えば、VBAを一切書かずに「数式の中で名前を付ける」「自分専用の関数を登録する」ことが可能です。読み終えたとき、長い数式は驚くほどスッキリし、コピペ地獄から解放されているはずです。</p>



<p class="wp-block-paragraph">実務例は全部で8パターン用意しました。LET実務例4つ、LAMBDA実務例3つ、組み合わせ実務例3つです。社内の請求書テンプレートや勤怠データ、評価ランク判定などすぐに転用できるものばかりです。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-1" checked><label class="toc-title" for="toc-checkbox-1">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">LET関数とLAMBDA関数、どう違う？1分でわかる役割整理</a><ol><li><a href="#toc2" tabindex="0">LET関数＝「セル内で変数を定義する」関数</a></li><li><a href="#toc3" tabindex="0">LAMBDA関数＝「ブック内で再利用できる関数を定義する」関数</a></li><li><a href="#toc4" tabindex="0">LETとLAMBDAの使い分け早見表</a></li></ol></li><li><a href="#toc5" tabindex="0">なぜ今LETとLAMBDAなのか｜従来のExcel数式が抱えていた3つの痛み</a><ol><li><a href="#toc6" tabindex="0">痛み①：同じ式の二度書き地獄</a></li><li><a href="#toc7" tabindex="0">痛み②：参照範囲の一括変更が漏れる</a></li><li><a href="#toc8" tabindex="0">痛み③：VBA UDFのセキュリティ警告</a></li></ol></li><li><a href="#toc9" tabindex="0">LET関数の基本：変数に名前をつけて数式をスッキリさせる</a><ol><li><a href="#toc10" tabindex="0">LET関数の基本構文</a></li><li><a href="#toc11" tabindex="0">実務例①：VLOOKUP+IFERRORを変数化してメンテナンスコストを削減</a></li><li><a href="#toc12" tabindex="0">実務例②：FILTER+SORTを段階的に書いてデバッグしやすくする</a></li><li><a href="#toc13" tabindex="0">実務例③：複雑な条件分岐の途中結果に名前を付ける</a></li><li><a href="#toc14" tabindex="0">実務例④：経理の累進計算をLETで段階分解</a></li><li><a href="#toc15" tabindex="0">Before / After 比較</a></li></ol></li><li><a href="#toc16" tabindex="0">LAMBDA関数の基本：名前定義で「自分の関数」を登録する手順</a><ol><li><a href="#toc17" tabindex="0">LAMBDA関数の基本構文</a></li><li><a href="#toc18" tabindex="0">名前の管理へ登録する手順</a></li><li><a href="#toc19" tabindex="0">実務例⑤：消費税計算をLAMBDA関数化して毎月使い回す</a></li><li><a href="#toc20" tabindex="0">実務例⑥：営業日換算LAMBDAで週末カウントを統一</a></li><li><a href="#toc21" tabindex="0">実務例⑦：評価ランクLAMBDAで成績判定を関数化</a></li></ol></li><li><a href="#toc22" tabindex="0">LAMBDA + ヘルパー関数で配列処理を一気に書く</a><ol><li><a href="#toc23" tabindex="0">MAP関数との連携（要素ごとにLAMBDAを適用）</a></li><li><a href="#toc24" tabindex="0">BYROW/BYCOLとの連携（行・列ごとの一括処理）</a></li></ol></li><li><a href="#toc25" tabindex="0">LET + LAMBDA を組み合わせる：実務頻出3パターン</a><ol><li><a href="#toc26" tabindex="0">パターン1：LETで中間変数を整理してからLAMBDAに渡す</a></li><li><a href="#toc27" tabindex="0">パターン2：FILTER+SORTの組み合わせをLET変数で段階的に書く</a></li><li><a href="#toc28" tabindex="0">パターン3：LAMBDA内部でLETを使ってロジックを可読化する</a></li></ol></li><li><a href="#toc29" tabindex="0">LET/LAMBDA vs VBA Function｜使い分けの判断基準</a></li><li><a href="#toc30" tabindex="0">こんなエラーが出たら：つまずきポイントと対処法</a><ol><li><a href="#toc31" tabindex="0">#NAME?エラーが出る原因と解決策</a></li><li><a href="#toc32" tabindex="0">#CALC!エラーが出る原因と解決策</a></li><li><a href="#toc33" tabindex="0">変数名にセル参照と同名を使ったときの挙動</a></li><li><a href="#toc34" tabindex="0">LAMBDAの再帰呼び出しでスタックオーバーフロー</a></li></ol></li><li><a href="#toc35" tabindex="0">よくある質問（FAQ）</a></li><li><a href="#toc36" tabindex="0">まとめ：LETは今日から、LAMBDAは次のステップで</a><ol><li><a href="#toc37" tabindex="0">関連記事で次のステップに進む</a></li></ol></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">LET関数とLAMBDA関数、どう違う？1分でわかる役割整理</span></h2>



<p class="wp-block-paragraph">LET関数とLAMBDA関数は、どちらも「数式に名前を付けて整理する」ための関数です。ただし、名前を付ける対象とスコープが大きく異なります。まずは両者の役割を1分で押さえましょう。</p>



<h3 class="wp-block-heading"><span id="toc2">LET関数＝「セル内で変数を定義する」関数</span></h3>



<p class="wp-block-paragraph">LET関数は、<strong>1つのセルの中だけで通用する「変数」</strong> を定義できる関数です。Excelの文脈では「数式の途中で計算結果に名前を付けておき、後で参照できる仕組み」と理解してください。プログラミング経験者なら「ローカル変数」のイメージです。</p>



<p class="wp-block-paragraph">たとえば <code>VLOOKUP(A2, $D:$E, 2, 0)</code> を <code>result</code> という名前で保存しておけば、後の式で <code>result</code> と書くだけで再利用できます。同じ式を2回書く必要がなく、計算も1回しか走らないのでパフォーマンスも向上します。</p>



<p class="wp-block-paragraph">ただしLET関数のスコープは <strong>「そのセル内のみ」</strong> に限定されます。他のセルや他のシートから <code>result</code> を参照することはできません。あくまで「そのセルを書くときの一時メモ帳」というイメージです。</p>



<h3 class="wp-block-heading"><span id="toc3">LAMBDA関数＝「ブック内で再利用できる関数を定義する」関数</span></h3>



<p class="wp-block-paragraph">LAMBDA関数は、<strong>ブック全体で使い回せる「自分専用の関数」</strong> を定義できる関数です。LAMBDA式を「名前の管理」に登録すると、ブックのどのシート・どのセルからも <code>=MY_FUNC(引数)</code> の形式で呼び出せます。</p>



<p class="wp-block-paragraph">これまでカスタム関数を作るにはVBAでユーザー定義関数（UDF）を書く必要がありました。LAMBDAなら <strong>VBAを一切使わずに、数式だけでカスタム関数を作成できます</strong>。マクロのセキュリティ警告も出ません。まるでプログラムのようですが、あくまでセルに書く数式の延長です。</p>



<p class="wp-block-paragraph">xlsx形式のまま配布できるため、メール添付やSharePoint共有もマクロ警告で止まらないという大きな利点もあります。</p>



<h3 class="wp-block-heading"><span id="toc4">LETとLAMBDAの使い分け早見表</span></h3>



<p class="wp-block-paragraph">両者の違いを「スコープ」と「役割」の2軸で整理すると、次の表になります。</p>



<figure class="wp-block-table"><table><thead><tr><th>観点</th><th>LET関数</th><th>LAMBDA関数</th></tr></thead><tbody><tr><td>役割</td><td>変数の定義</td><td>関数の定義</td></tr><tr><td>スコープ</td><td>セル内のみ</td><td>ブック全体（名前定義で登録時）</td></tr><tr><td>再利用</td><td>同じセル内のみ</td><td>他セル・他シートからも呼び出し可</td></tr><tr><td>主な用途</td><td>1つの長い数式の整理・可読性向上</td><td>複数箇所で繰り返す計算ロジックの関数化</td></tr><tr><td>対応バージョン</td><td>Microsoft 365 / Excel 2021以降</td><td>Microsoft 365のみ（Excel 2021非対応）</td></tr><tr><td>VBAの必要性</td><td>不要</td><td>不要</td></tr><tr><td>配布形式</td><td>xlsx</td><td>xlsx</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">ここで重要なのが <strong>バージョン差分</strong> です。LET関数はExcel 2021でも使えますが、LAMBDA関数はMicrosoft 365専用です。自分のバージョンを確認するには「ファイル」→「アカウント」→「製品情報」を見てください。</p>



<p class="wp-block-paragraph">!<a href="https://mashukabu.com/_images/excel-let-lambda-function-guide/01_data_let-lambda-comparison.png/">_images/excel-let-lambda-function-guide/01_data_let-lambda-comparison.png</a></p>



<h2 class="wp-block-heading"><span id="toc5">なぜ今LETとLAMBDAなのか｜従来のExcel数式が抱えていた3つの痛み</span></h2>



<p class="wp-block-paragraph">LETとLAMBDAの説明に入る前に、「なぜこの2関数が必要になったのか」を整理しておきます。従来のExcel数式には、慣れた人ほど直面する3つの痛みがありました。</p>



<h3 class="wp-block-heading"><span id="toc6">痛み①：同じ式の二度書き地獄</span></h3>



<p class="wp-block-paragraph">最も典型的なのが「条件分岐の中で同じ計算を2回書く」パターンです。たとえばVLOOKUPで取得した値が空欄なら「未登録」、そうでなければそのまま表示したい場合、こう書くしかありませんでした。</p>



<pre class="wp-block-code"><code>'--- 二度書きが避けられない従来の数式 ---
=IF(VLOOKUP(A2,$D:$E,2,0)=&quot;&quot;, &quot;未登録&quot;, VLOOKUP(A2,$D:$E,2,0))</code></pre>



<p class="wp-block-paragraph">VLOOKUP部分が2か所に出てきます。参照範囲を変えたいときは2か所同時に修正しなければなりません。1か所でも直し忘れると <code>#N/A</code> が混ざる悲劇が起こります。さらに同じVLOOKUPが2回実行されるため、データが大きいときは計算速度も無駄になります。</p>



<p class="wp-block-paragraph">条件分岐の基本については <a href="https://mashukabu.com/excel-function-howto-use-if/">ExcelのIF関数の使い方</a> で詳しく解説しています。</p>



<h3 class="wp-block-heading"><span id="toc7">痛み②：参照範囲の一括変更が漏れる</span></h3>



<p class="wp-block-paragraph">数式を100セルにコピーした後で「参照範囲を <code>$D:$E</code> から <code>$D:$F</code> に変えたい」と思ったときが地獄です。すべての数式を編集モードで開き、置換ダイアログか手作業で書き換えるしかありません。</p>



<p class="wp-block-paragraph">VLOOKUPを多用している方は <a href="https://mashukabu.com/excel-function-howto-use-vlookup/">ExcelのVLOOKUP関数の使い方</a> も合わせてご覧ください。参照範囲の管理が一気に楽になります。</p>



<h3 class="wp-block-heading"><span id="toc8">痛み③：VBA UDFのセキュリティ警告</span></h3>



<p class="wp-block-paragraph">「だったらVBAでカスタム関数を作ればいい」と考える方もいるでしょう。実際 <a href="https://mashukabu.com/excel-vba-howto-use-function/">VBAのFunctionプロシージャ</a> を使えばカスタム関数（UDF）が作れます。しかし配布時に問題が起きます。</p>



<p class="wp-block-paragraph">VBA入りのブックは「マクロ有効ブック（xlsm）」になり、開いた人に「マクロを有効にしますか？」というセキュリティ警告が必ず出ます。社内ポリシーで「不明なマクロは無効化」が設定されている会社では、せっかくのUDFが動きません。</p>



<p class="wp-block-paragraph">LET/LAMBDAなら <strong>xlsxのまま</strong> カスタム関数を作れるため、この壁を完全に回避できます。</p>



<h2 class="wp-block-heading"><span id="toc9">LET関数の基本：変数に名前をつけて数式をスッキリさせる</span></h2>



<p class="wp-block-paragraph">LET関数は、長くてネストが深い数式を「段階的に名前を付けながら組み立てる」イメージで使います。難しく考える必要はなく、「途中の計算結果に名前を付けておく」だけです。</p>



<h3 class="wp-block-heading"><span id="toc10">LET関数の基本構文</span></h3>



<p class="wp-block-paragraph">LET関数の構文は次のとおりです。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>内容</th></tr></thead><tbody><tr><td>構文</td><td><code>=LET(name1, value1, [name2, value2, …,] calculation)</code></td></tr><tr><td>必須引数</td><td>最低1組の「名前・値」と、最後に必ず計算式</td></tr><tr><td>最大ペア数</td><td>126個の名前/値ペア</td></tr><tr><td>変数名の制約</td><td>文字で始まる／スペース不可／セル参照（A1等）と同名不可／TRUE・FALSE等の予約語不可</td></tr><tr><td>対応バージョン</td><td>Microsoft 365 / Excel 2021以降</td></tr><tr><td>出典</td><td><a href="https://support.microsoft.com/en-us/office/let-function-34842dd8-b92b-4d3f-b325-b8b8f9908999">Microsoft公式: LET関数</a></td></tr></tbody></table></figure>



<p class="wp-block-paragraph">最もシンプルな例を見てみましょう。</p>



<pre class="wp-block-code"><code>'--- LET関数の最小サンプル ---
=LET(x, 5, SUM(x, 1))</code></pre>



<p class="wp-block-paragraph">この式は「<code>x</code> に <code>5</code> を代入し、<code>SUM(x, 1)</code> を計算する」という意味で、結果は <code>6</code> になります。Excelの文脈では「数式の中で名前付きの一時変数を作れる」と理解すれば十分です。</p>



<p class="wp-block-paragraph">ここからは実務で本当に役立つLETの使い方を、4つの実例で解説していきます。</p>



<h3 class="wp-block-heading"><span id="toc11">実務例①：VLOOKUP+IFERRORを変数化してメンテナンスコストを削減</span></h3>



<p class="wp-block-paragraph">LETが最も威力を発揮するのは、<strong>同じ式を複数回書かなければならない場面</strong> です。代表例が「VLOOKUPの結果をIFERRORで包む」パターンです。</p>



<p class="wp-block-paragraph">通常の書き方では、VLOOKUPを2回書く必要があります。</p>



<pre class="wp-block-code"><code>'--- LETなしの従来パターン（VLOOKUPが2回登場） ---
=IF(VLOOKUP(A2, $D:$E, 2, 0)=&quot;&quot;, &quot;未登録&quot;, VLOOKUP(A2, $D:$E, 2, 0))</code></pre>



<p class="wp-block-paragraph">参照範囲を <code>$D:$F</code> に変えたいとき、2か所すべてを直さないと結果が狂います。これをLETで書き換えるとこうなります。</p>



<pre class="wp-block-code"><code>'--- LETあり：1か所修正で済む新パターン ---
=LET(
  result, VLOOKUP(A2, $D:$E, 2, 0),
  IF(result=&quot;&quot;, &quot;未登録&quot;, result)
)</code></pre>



<p class="wp-block-paragraph">VLOOKUP部分が <code>result</code> という変数1か所だけになりました。参照範囲を変更したいときは <code>result</code> の定義行だけ直せばよく、メンテナンスコストが半分以下になります。さらにVLOOKUPは1回しか実行されないため、計算速度の面でも有利です。</p>



<p class="wp-block-paragraph">VLOOKUPの基本的な使い方を再確認したい方は <a href="https://mashukabu.com/excel-function-howto-use-vlookup/">ExcelのVLOOKUP関数の使い方</a> を参照してください。エラー処理を厚くしたい方は <a href="https://mashukabu.com/excel-function-howto-use-iferror/">ExcelのIFERROR関数の使い方</a> も合わせてご覧ください。</p>



<h3 class="wp-block-heading"><span id="toc12">実務例②：FILTER+SORTを段階的に書いてデバッグしやすくする</span></h3>



<p class="wp-block-paragraph">動的配列関数（FILTER, SORT, UNIQUE等）を組み合わせると、1セルに長い式が並びがちです。LETを使うと「フィルタしてからソート」という処理を段階的に書けます。</p>



<pre class="wp-block-code"><code>'--- 動的配列関数を段階化したサンプル ---
=LET(
  filtered, FILTER(A2:C100, B2:B100=&quot;東京&quot;),
  sorted,   SORT(filtered, 3, -1),
  sorted
)</code></pre>



<p class="wp-block-paragraph"><code>filtered</code> の段階だけ表示すれば「フィルタが正しいか」を確認できます。次に <code>sorted</code> を返せば「ソートも正しいか」が見えます。長い数式を1行ずつデバッグできる構造になるのが利点です。</p>



<p class="wp-block-paragraph">慣れてくれば、最後の <code>sorted</code> を <code>INDEX(sorted, 1, 3)</code> などに差し替えて「ソート後の1行目の3列目だけ抜く」という応用にもつなげられます。</p>



<h3 class="wp-block-heading"><span id="toc13">実務例③：複雑な条件分岐の途中結果に名前を付ける</span></h3>



<p class="wp-block-paragraph">「売上が100万円以上、かつ達成率が80%以上ならA評価」のような複合条件は、IF/IFSの入れ子で書くと読みにくくなりがちです。LETで条件を変数化すると意図が明確になります。</p>



<pre class="wp-block-code"><code>'--- 複合条件をLETで整理した例 ---
=LET(
  sales,      B2,
  rate,       C2,
  isHighSale, sales &gt;= 1000000,
  isHighRate, rate  &gt;= 0.8,
  IF(AND(isHighSale, isHighRate), &quot;A評価&quot;,
   IF(isHighSale, &quot;B評価&quot;,
   IF(isHighRate, &quot;C評価&quot;, &quot;D評価&quot;)))
)</code></pre>



<p class="wp-block-paragraph"><code>isHighSale</code> <code>isHighRate</code> という変数名のおかげで、後から読み返したときに「何を判定しているか」が一目で分かります。半年後の自分にも親切な数式です。</p>



<p class="wp-block-paragraph">条件分岐の組み合わせをさらに深掘りしたい方は <a href="https://mashukabu.com/excel-function-howto-use-if/">ExcelのIF関数の使い方</a> で基本パターンを確認してください。</p>



<h3 class="wp-block-heading"><span id="toc14">実務例④：経理の累進計算をLETで段階分解</span></h3>



<p class="wp-block-paragraph">経理処理で「税抜金額 → 消費税 → 端数処理 → 税込金額」という多段階計算は、LETの段階分解と相性が抜群です。</p>



<pre class="wp-block-code"><code>'--- 経理の段階計算を可視化 ---
=LET(
  taxRate,   0.1,
  netPrice,  B2,
  tax,       ROUND(netPrice * taxRate, 0),
  gross,     netPrice + tax,
  gross
)</code></pre>



<p class="wp-block-paragraph">消費税率が変わったときも、最初の <code>taxRate</code> の値だけを直せば全体に反映されます。各ステップに変数名が付いているため、デバッグで「途中の <code>tax</code> の値が想定と違う」と気づきやすくなります。</p>



<h3 class="wp-block-heading"><span id="toc15">Before / After 比較</span></h3>



<p class="wp-block-paragraph">LETを導入する前と後で、数式の見た目がどう変わるかを比較します。</p>



<p class="wp-block-paragraph"><strong>Before（LETなし）</strong></p>



<pre class="wp-block-code"><code>'--- 従来：氏名と部署を1セルに連結する力技 ---
=IFERROR(VLOOKUP(A2,$D:$E,2,0),&quot;該当なし&quot;)&amp;&quot; / &quot;&amp;IFERROR(VLOOKUP(A2,$D:$F,3,0),&quot;該当なし&quot;)</code></pre>



<p class="wp-block-paragraph"><strong>After（LETあり）</strong></p>



<pre class="wp-block-code"><code>'--- After：1行ずつ意味が読み取れる ---
=LET(
  name,  IFERROR(VLOOKUP(A2,$D:$E,2,0),&quot;該当なし&quot;),
  dept,  IFERROR(VLOOKUP(A2,$D:$F,3,0),&quot;該当なし&quot;),
  name &amp; &quot; / &quot; &amp; dept
)</code></pre>



<p class="wp-block-paragraph">After版は1行ずつ「何を計算しているか」が読み取れます。半年後に自分が見直しても、別の担当者が引き継いでも理解しやすくなります。</p>



<figure class="wp-block-image"><img decoding="async" src="https://mashukabu.com/wp-content/uploads/2026/05/02_result_let-before-after.png" alt="02 result let before after" /></figure>



<p class="wp-block-paragraph">LET関数のもっと詳しい仕様や応用例については <a href="https://mashukabu.com/excel-function-howto-use-let/">ExcelのLET関数の使い方｜変数定義で数式を短く整理する方法</a> で個別に解説しています。深掘りしたい方はそちらもご参照ください。</p>



<h2 class="wp-block-heading"><span id="toc16">LAMBDA関数の基本：名前定義で「自分の関数」を登録する手順</span></h2>



<p class="wp-block-paragraph">LAMBDA関数は、LETの一歩先にある「数式を関数化して使い回す」ための仕組みです。冒頭で触れたとおり <strong>Microsoft 365専用</strong> なので、Excel 2021ユーザーは利用できない点にご注意ください。</p>



<h3 class="wp-block-heading"><span id="toc17">LAMBDA関数の基本構文</span></h3>



<p class="wp-block-paragraph">LAMBDA関数の構文は次のとおりです。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>内容</th></tr></thead><tbody><tr><td>構文</td><td><code>=LAMBDA([parameter1, parameter2, …,] calculation)</code></td></tr><tr><td>必須引数</td><td>最後の計算式（パラメータは省略可）</td></tr><tr><td>最大パラメータ数</td><td>253個</td></tr><tr><td>即時呼び出し</td><td><code>=LAMBDA(temp, (5/9)*(temp-32))(100)</code> のように末尾に引数を渡す</td></tr><tr><td>名前定義への登録</td><td>「数式」タブ→「名前の管理」→「新規」から登録</td></tr><tr><td>対応バージョン</td><td>Microsoft 365専用（Excel 2021は非対応）</td></tr><tr><td>出典</td><td><a href="https://support.microsoft.com/en-us/office/lambda-function-bd212d27-1cd1-4321-a34a-ccbf254b8b67">Microsoft公式: LAMBDA関数</a></td></tr></tbody></table></figure>



<p class="wp-block-paragraph">LAMBDAを単独でセルに書くだけでは関数の「定義」しかできません。末尾に引数を渡さないと <code>#CALC!</code> エラーが出ます。本来の使い方は「名前の管理」に登録してから呼び出す形です。</p>



<h3 class="wp-block-heading"><span id="toc18">名前の管理へ登録する手順</span></h3>



<p class="wp-block-paragraph">LAMBDA関数を実用するには「名前の管理」への登録が必須です。Windows版Excelでの手順は以下のとおりです。</p>



<ol class="wp-block-list"><li><strong>「数式」タブ</strong> をクリックする</li><li><strong>「名前の管理」</strong> をクリック（ショートカット: <code>Ctrl + F3</code>）</li><li>ダイアログ右上の <strong>「新規」</strong> をクリック</li><li>「新しい名前」ダイアログで以下を入力する</li></ol>



<ul class="wp-block-list"><li><strong>名前</strong>: 関数名（例: <code>TAX_CALC</code>）。Excelの既存関数名と被らないようにする</li><li><strong>範囲</strong>: 通常は「ブック」を選択（シートを選ぶと他シートから呼び出せない）</li><li><strong>コメント</strong>: 関数の説明（後で見返したときに役立つ）</li><li><strong>参照範囲</strong>: LAMBDA式を貼り付ける（例: <code>=LAMBDA(price, price*1.1)</code>）</li></ul>



<ol class="wp-block-list"><li><strong>「OK」</strong> をクリックして登録完了</li></ol>



<p class="wp-block-paragraph">登録が成功すると、そのブック内のどのセルでも <code>=TAX_CALC(1000)</code> のようにネイティブ関数と同じ感覚で呼び出せるようになります。</p>



<p class="wp-block-paragraph">※ 名前の管理ダイアログの操作画面は、デスクトップ版Excel（Windows）でご確認ください。</p>



<h3 class="wp-block-heading"><span id="toc19">実務例⑤：消費税計算をLAMBDA関数化して毎月使い回す</span></h3>



<p class="wp-block-paragraph">毎月の請求書で「税抜価格 × 1.1」の式を何十か所にも書いているなら、LAMBDA化の絶好のチャンスです。次のLAMBDA式を <code>TAX_INCLUDED</code> という名前で登録してみましょう。</p>



<pre class="wp-block-code"><code>'--- 名前の管理に登録するLAMBDA式 ---
=LAMBDA(price, ROUND(price*1.1, 0))</code></pre>



<p class="wp-block-paragraph">登録後はどのセルでも次のように使えます。</p>



<pre class="wp-block-code"><code>'--- 通常の関数として呼び出し可能 ---
=TAX_INCLUDED(B2)</code></pre>



<p class="wp-block-paragraph">将来、消費税率が変わったり端数処理を「切り捨て」に変えたいときは、<strong>「名前の管理」のLAMBDA式を1か所書き換えるだけ</strong> で全体に反映されます。コピペした数式を100か所修正する必要は一切ありません。</p>



<h3 class="wp-block-heading"><span id="toc20">実務例⑥：営業日換算LAMBDAで週末カウントを統一</span></h3>



<p class="wp-block-paragraph">「ある日付からN営業日後の日付を返す」という処理は、社内の勤怠管理や納期計算で頻出です。NETWORKDAYSやWORKDAYを毎回書くのではなく、LAMBDA化すると統一できます。</p>



<pre class="wp-block-code"><code>'--- WORKDAY_AFTER として名前登録 ---
=LAMBDA(startDate, days, WORKDAY(startDate, days))</code></pre>



<p class="wp-block-paragraph">呼び出し例:</p>



<pre class="wp-block-code"><code>'--- 5営業日後の日付を取得 ---
=WORKDAY_AFTER(TODAY(), 5)</code></pre>



<p class="wp-block-paragraph">祝日リストも引数に加えたければ、次のように拡張できます。</p>



<pre class="wp-block-code"><code>'--- 祝日対応版 WORKDAY_AFTER ---
=LAMBDA(startDate, days, holidays, WORKDAY(startDate, days, holidays))</code></pre>



<p class="wp-block-paragraph">このようにLAMBDAは「あとから引数を増やす」拡張も柔軟にできます。</p>



<h3 class="wp-block-heading"><span id="toc21">実務例⑦：評価ランクLAMBDAで成績判定を関数化</span></h3>



<p class="wp-block-paragraph">「点数からA/B/C/D評価を返す」というような判定ロジックは、複数のシートで同じ閾値を使うことが多く、LAMBDA向きです。</p>



<pre class="wp-block-code"><code>'--- RANK_GRADE として名前登録 ---
=LAMBDA(score,
  IF(score &gt;= 80, &quot;A&quot;,
   IF(score &gt;= 60, &quot;B&quot;,
    IF(score &gt;= 40, &quot;C&quot;, &quot;D&quot;)))
)</code></pre>



<p class="wp-block-paragraph">呼び出し:</p>



<pre class="wp-block-code"><code>'--- セルB2の点数から評価を取得 ---
=RANK_GRADE(B2)</code></pre>



<p class="wp-block-paragraph">評価基準が「80→85」に変わったとしても、名前の管理にあるLAMBDA式の1か所を直すだけで、社内の全シートに反映されます。担当者ごとの判定ブレも防げます。</p>



<h2 class="wp-block-heading"><span id="toc22">LAMBDA + ヘルパー関数で配列処理を一気に書く</span></h2>



<p class="wp-block-paragraph">LAMBDA関数の真価は、<strong>MAP/BYROW/BYCOL/REDUCE等のヘルパー関数と組み合わせたとき</strong> に現れます。これらは「LAMBDA式を受け取って、配列の各要素に適用する」高階関数です。</p>



<h3 class="wp-block-heading"><span id="toc23">MAP関数との連携（要素ごとにLAMBDAを適用）</span></h3>



<p class="wp-block-paragraph">MAP関数は、配列の各要素に対してLAMBDAを実行し、結果を配列で返します。たとえば「A2:A10 の全ての値に税込計算を適用したい」とき、次のように書けます。</p>



<pre class="wp-block-code"><code>'--- A2:A10の全要素にTAX_INCLUDEDを適用 ---
=MAP(A2:A10, LAMBDA(x, ROUND(x*1.1, 0)))</code></pre>



<p class="wp-block-paragraph">これでスピル動作により、隣の列に税込価格が9行分一気に展開されます。LAMBDAを毎セルにコピーする必要はありません。</p>



<p class="wp-block-paragraph">MAP関数の詳しい使い方は <a href="https://mashukabu.com/excel-function-howto-use-map/">ExcelのMAP関数の使い方</a> で個別解説しています。</p>



<h3 class="wp-block-heading"><span id="toc24">BYROW/BYCOLとの連携（行・列ごとの一括処理）</span></h3>



<p class="wp-block-paragraph">BYROW関数は「行ごと」に処理をかけ、BYCOL関数は「列ごと」に処理をかけます。たとえば「各行の最大値を取り出す」ならBYROWが便利です。</p>



<pre class="wp-block-code"><code>'--- 各行の最大値を取得 ---
=BYROW(A2:D10, LAMBDA(row, MAX(row)))</code></pre>



<p class="wp-block-paragraph">3列の合計を行単位で出したいなら次のとおりです。</p>



<pre class="wp-block-code"><code>'--- 各行の合計を取得 ---
=BYROW(A2:C10, LAMBDA(row, SUM(row)))</code></pre>



<p class="wp-block-paragraph">集計関数（SUM/MAX/MIN/AVERAGE）をLAMBDA経由で渡すだけで、行・列単位の一括処理が完了します。SUMPRODUCTや配列数式の代わりに使えるシーンが多く、慣れると手放せません。</p>



<h2 class="wp-block-heading"><span id="toc25">LET + LAMBDA を組み合わせる：実務頻出3パターン</span></h2>



<p class="wp-block-paragraph">LETとLAMBDAは単独でも便利ですが、<strong>組み合わせると真価を発揮します</strong>。ここでは実務頻出の3パターンを紹介します。</p>



<h3 class="wp-block-heading"><span id="toc26">パターン1：LETで中間変数を整理してからLAMBDAに渡す</span></h3>



<p class="wp-block-paragraph">外側の数式でLETを使ってデータを整え、整えた結果をLAMBDAベースのカスタム関数に渡す書き方です。</p>



<pre class="wp-block-code"><code>'--- LETでデータ整形→LAMBDA関数を呼び出す ---
=LET(
  raw,    FILTER(A2:C100, B2:B100=&quot;東京&quot;),
  sorted, SORT(raw, 3, -1),
  TAX_INCLUDED(INDEX(sorted, 1, 3))
)</code></pre>



<p class="wp-block-paragraph">中間結果に名前を付けることで「フィルタ→ソート→税込変換」という処理の流れが明確になります。</p>



<h3 class="wp-block-heading"><span id="toc27">パターン2：FILTER+SORTの組み合わせをLET変数で段階的に書く</span></h3>



<p class="wp-block-paragraph">LAMBDAを使わなくても、LET単体で動的配列関数を段階的に書けます。</p>



<pre class="wp-block-code"><code>'--- 動的配列関数を段階化 ---
=LET(
  filtered, FILTER(A2:C10, B2:B10=&quot;東京&quot;),
  SORT(filtered, 3, -1)
)</code></pre>



<p class="wp-block-paragraph">東京のデータだけを抽出し、3列目で降順ソートする処理を「2段階」で書いています。中間結果の <code>filtered</code> だけを表示すれば動作確認ができるため、デバッグも容易です。</p>



<h3 class="wp-block-heading"><span id="toc28">パターン3：LAMBDA内部でLETを使ってロジックを可読化する</span></h3>



<p class="wp-block-paragraph">LAMBDAで複雑な計算をするとき、内部にLETを入れ子にして中間変数を整理できます。</p>



<pre class="wp-block-code"><code>'--- LAMBDA内部にLETを入れ子で書く ---
=LAMBDA(price,
  LET(
    base, price * 1.1,
    tax,  base * 0.1,
    base + tax
  )
)</code></pre>



<p class="wp-block-paragraph">この式を <code>TAX_DETAIL</code> として登録すれば、<code>=TAX_DETAIL(1000)</code> で呼び出せます。LAMBDAの引数 <code>price</code> を受け取り、LETで段階的に <code>base</code> と <code>tax</code> を計算してから合計を返す構造です。</p>



<h2 class="wp-block-heading"><span id="toc29">LET/LAMBDA vs VBA Function｜使い分けの判断基準</span></h2>



<p class="wp-block-paragraph">「カスタム関数を作るならLAMBDAとVBA UDF、どちらを選ぶべきか」は多くの方が悩む点です。両者を実務観点で比較します。</p>



<figure class="wp-block-table"><table><thead><tr><th>観点</th><th>LAMBDA関数</th><th>VBA Functionプロシージャ</th></tr></thead><tbody><tr><td>作成手段</td><td>数式のみ</td><td>VBAコード（VBE）</td></tr><tr><td>配布形式</td><td>xlsx</td><td>xlsm（マクロ有効ブック）</td></tr><tr><td>セキュリティ警告</td><td>出ない</td><td>出る</td></tr><tr><td>計算速度</td><td>数式と同等</td><td>やや遅い場合あり</td></tr><tr><td>対応バージョン</td><td>Microsoft 365のみ</td><td>VBA対応のExcel全般</td></tr><tr><td>可能な処理</td><td>数式で書ける範囲</td><td>ファイル操作・API呼出・複雑制御も可</td></tr><tr><td>デバッグ</td><td>LETの中間変数で確認</td><td>ブレークポイント・イミディエイト</td></tr><tr><td>学習コスト</td><td>Excelの数式知識のみ</td><td>VBA文法を学ぶ必要あり</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">判断基準を実務シーン別に整理すると次のとおりです。</p>



<ul class="wp-block-list"><li><strong>xlsxのまま配布したい・社内のマクロ警告を回避したい</strong> → LAMBDA</li><li><strong>計算式の延長で済む処理（税込・営業日・評価判定など）</strong> → LAMBDA</li><li><strong>Excel 2021や旧バージョンのユーザーがいる</strong> → VBA Function（LAMBDAは使えない）</li><li><strong>ファイル操作・正規表現・WEB API呼び出しが必要</strong> → VBA Function</li><li><strong>長年VBA UDFで運用していて移行コストが高い</strong> → VBA Functionを継続</li></ul>



<p class="wp-block-paragraph">VBAのFunctionプロシージャの基本については <a href="https://mashukabu.com/excel-vba-howto-use-function/">VBA Functionプロシージャの使い方</a> で詳しく解説しています。両者の使い分けを社内で標準化したい方は、まずLAMBDAで実装してみて、できない処理だけVBAに移すアプローチが現実的です。</p>



<h2 class="wp-block-heading"><span id="toc30">こんなエラーが出たら：つまずきポイントと対処法</span></h2>



<p class="wp-block-paragraph">LET/LAMBDAは強力ですが、慣れないうちはエラーに遭遇します。代表的な4つのケースと対処法をまとめます。</p>



<h3 class="wp-block-heading"><span id="toc31">#NAME?エラーが出る原因と解決策</span></h3>



<p class="wp-block-paragraph"><code>#NAME?</code> エラーは、Excelが関数名や変数名を認識できないときに発生します。主な原因は3つです。</p>



<ol class="wp-block-list"><li><strong>バージョン非対応</strong>: Excel 2019以前でLETを使うと出ます。LAMBDAはExcel 2021でも非対応なので注意してください</li><li><strong>関数名のスペルミス</strong>: <code>=LET</code> を <code>=LTE</code> などとタイプミスしている</li><li><strong>名前定義の未登録</strong>: <code>=TAX_CALC(100)</code> と呼んでも、「名前の管理」に未登録なら認識されません</li></ol>



<p class="wp-block-paragraph">対処は「バージョン確認 → スペル確認 → 名前の管理で登録状態を確認」の順で切り分けます。エラー処理を厚くしたいなら <a href="https://mashukabu.com/excel-function-howto-use-iferror/">ExcelのIFERROR関数の使い方</a> を組み合わせてください。</p>



<h3 class="wp-block-heading"><span id="toc32">#CALC!エラーが出る原因と解決策</span></h3>



<p class="wp-block-paragraph"><code>#CALC!</code> エラーは、LAMBDAをセルに書いた際に <strong>末尾の引数渡しを忘れた</strong> ときの典型エラーです。たとえば次の式はエラーになります。</p>



<pre class="wp-block-code"><code>'--- これは#CALC!エラーになる ---
=LAMBDA(temp, (5/9)*(temp-32))</code></pre>



<p class="wp-block-paragraph">セル内で即時呼び出しするには末尾に <code>(100)</code> のように引数を付けます。</p>



<pre class="wp-block-code"><code>'--- 末尾に引数を渡せば正常動作 ---
=LAMBDA(temp, (5/9)*(temp-32))(100)</code></pre>



<p class="wp-block-paragraph">なお、名前定義に登録したLAMBDAを呼び出す場合は <code>=MY_FUNC(100)</code> の形で問題ありません。</p>



<h3 class="wp-block-heading"><span id="toc33">変数名にセル参照と同名を使ったときの挙動</span></h3>



<p class="wp-block-paragraph">LETの変数名に <code>A1</code> や <code>B2</code> のような「セル参照と同名」を使うと、Excelは予期しない動作をする可能性があります。たとえば以下の式は本来意図した動作にならない恐れがあります。</p>



<pre class="wp-block-code"><code>'--- セル参照と同名はNG ---
=LET(A1, 10, A1*2)</code></pre>



<p class="wp-block-paragraph">LETの仕様上「変数名はセル参照と同名にしない」というルールがあります。<code>price</code> や <code>taxRate</code> のように <strong>意味のある名前</strong> を必ず付けてください。可読性の面でも重要です。</p>



<h3 class="wp-block-heading"><span id="toc34">LAMBDAの再帰呼び出しでスタックオーバーフロー</span></h3>



<p class="wp-block-paragraph">LAMBDAは自分自身を呼び出す「再帰」が可能ですが、停止条件を書き忘れるとExcelがフリーズします。階乗計算の例で見てみましょう。</p>



<pre class="wp-block-code"><code>'--- FACT_LAMBDA として登録するイメージ ---
=LAMBDA(n, IF(n&lt;=1, 1, n * FACT_LAMBDA(n-1)))</code></pre>



<p class="wp-block-paragraph"><code>n<=1</code> という停止条件を抜くと無限ループになり、最悪Excelが応答不能になります。再帰LAMBDAを書くときは必ず停止条件を最初に書く癖を付けてください。</p>



<h2 class="wp-block-heading"><span id="toc35">よくある質問（FAQ）</span></h2>



<p class="wp-block-paragraph">[faq q="LET関数とLAMBDA関数の最大の違いは何ですか？" a="スコープと役割が違います。LET関数は「1つのセル内だけで使える変数」を作るためのもの、LAMBDA関数は「ブック全体で使い回せるカスタム関数」を作るためのものです。LETは長い数式を整理する用途、LAMBDAは複数箇所で同じ計算ロジックを再利用する用途で使い分けます。"]<br>[faq q="Excel 2019や2016ではLET・LAMBDAは使えますか？" a="使えません。LET関数はExcel 2021 / Microsoft 365以降が必須、LAMBDA関数はMicrosoft 365専用です。Excel 2019以前のバージョンで開くと#NAME?エラーになります。社外に共有する場合は、相手のExcelバージョンを必ず確認してください。"]<br>[faq q="LAMBDA関数で作ったカスタム関数は他のブックでも使えますか？" a="そのままでは使えません。LAMBDA関数は「名前の管理」に登録するため、登録したブック内でのみ有効です。他のブックでも使うには、各ブックで同じLAMBDA式を再登録するか、テンプレートブックを共有して全員にコピーしてもらう運用が一般的です。"]<br>[faq q="LAMBDA関数にマクロのセキュリティ警告は出ますか？" a="出ません。LAMBDAは数式の延長なので、ファイル形式もxlsxのままで配布できます。VBAのユーザー定義関数（UDF）と違い、開いた人にマクロ警告が出ないため、社内ポリシーでマクロが制限されている環境でも安心して配布できます。"]<br>[faq q="LET関数の変数名に使ってはいけないものはありますか？" a="4つの制約があります。1. 数字や記号で始まる名前（例: 1stValue）、2. スペースを含む名前、3. A1やB2などのセル参照と同じ名前、4. TRUE・FALSE・NULLなどの予約語、これらは使えません。安全な命名は「英小文字で始まる意味のある名前（例: result, taxRate, totalPrice）」です。"]<br>[faq q="LAMBDAとVBAのユーザー定義関数(UDF)はどちらを使うべきですか？" a="数式で書ける範囲ならLAMBDAを優先するのがおすすめです。xlsxのまま配布でき、セキュリティ警告も出ないからです。ただしファイル操作・正規表現・WEB API呼び出しなど数式で書けない処理はVBA UDFが必要です。Microsoft 365が使えない環境ではVBA UDFを選びましょう。"]</p>



<h2 class="wp-block-heading"><span id="toc36">まとめ：LETは今日から、LAMBDAは次のステップで</span></h2>



<p class="wp-block-paragraph">LET関数とLAMBDA関数は、ExcelをVBAなしで「自分仕様」にカスタマイズできる強力な仕組みです。最後に本記事の要点を整理します。</p>



<ul class="wp-block-list"><li><strong>LET関数</strong>: セル内で変数を定義し、長い数式を整理する。Excel 2021以降で利用可</li><li><strong>LAMBDA関数</strong>: ブック全体で再利用できるカスタム関数を定義する。Microsoft 365専用</li><li><strong>使い分け</strong>: 1セル完結ならLET、複数箇所で繰り返すならLAMBDA</li><li><strong>組み合わせ</strong>: LAMBDA内部でLETを使えば、関数の内部ロジックを段階的に書けて可読性が大幅向上</li><li><strong>エラー対処</strong>: <code>#NAME?</code> はバージョン・スペル・名前登録、<code>#CALC!</code> はLAMBDA末尾の引数渡し忘れ</li><li><strong>VBAとの違い</strong>: xlsxのまま配布可・セキュリティ警告なし・ただしMicrosoft 365専用</li></ul>



<p class="wp-block-paragraph">まずは今日からLETを試してみてください。長いVLOOKUP+IFERRORの数式を <code>result</code> という変数1つで括るだけで、メンテナンス性が大きく変わります。LETの操作に慣れたら、次のステップとしてLAMBDA関数を1つだけ「名前の管理」に登録してみましょう。消費税計算でも単価計算でもかまいません。1つでも自作の関数がブックに登録できると、Excelとの付き合い方そのものが変わります。</p>



<p class="wp-block-paragraph">VBAに踏み込まなくても、数式だけでここまで自動化できる時代になりました。<strong>「数式に名前を付ける」</strong> という小さな一歩から、メンテナンスしやすく再利用可能なExcel運用を始めていきましょう。</p>



<h3 class="wp-block-heading"><span id="toc37">関連記事で次のステップに進む</span></h3>



<p class="wp-block-paragraph">LET/LAMBDAを使いこなすうえで、合わせて押さえておきたい関数記事を紹介します。</p>



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-function-howto-use-vlookup/">ExcelのVLOOKUP関数の使い方</a>：LET実務例①で必須の検索関数</li><li><a href="https://mashukabu.com/excel-function-howto-use-if/">ExcelのIF関数の使い方</a>：複合条件をLETで整理する前に基礎を確認</li><li><a href="https://mashukabu.com/excel-function-howto-use-iferror/">ExcelのIFERROR関数の使い方</a>：エラー処理の標準パターン</li><li><a href="https://mashukabu.com/excel-function-howto-use-map/">ExcelのMAP関数の使い方</a>：LAMBDAとの相棒、配列一括処理の要</li><li><a href="https://mashukabu.com/excel-vba-howto-use-function/">VBA Functionプロシージャの使い方</a>：LAMBDAで足りないケースの代替手段</li><li><a href="https://mashukabu.com/excel-function-list-by-function/">Excel関数一覧【機能別】</a>：他の便利関数を機能別に俯瞰</li></ul>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-let-lambda-function-guide/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>ExcelのLET関数の使い方｜変数定義で数式を短く整理する方法</title>
		<link>https://mashukabu.com/excel-function-howto-use-let/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-let/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 04 Apr 2026 04:32:16 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[LET関数]]></category>
		<category><![CDATA[Microsoft 365]]></category>
		<category><![CDATA[変数定義]]></category>
		<category><![CDATA[数式整理]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=5770</guid>

					<description><![CDATA[ExcelのLET関数の使い方を基本から解説。変数定義で数式を短く整理する方法、VLOOKUPやIFとの組み合わせ、パフォーマンス改善の仕組み、LAMBDA関数との違いまで実例付きで紹介します。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">「この数式、長すぎて何をやってるかわからない&#8230;」。Excelで複雑な数式を組んでいると、こんな場面によく出くわしますよね。</p>



<p class="wp-block-paragraph">しかも同じ計算を数式の中で何度も繰り返していると、修正するときにどこを直せばいいのか迷ってしまいます。1か所直し忘れてエラーになった経験がある人も多いのではないでしょうか。</p>



<p class="wp-block-paragraph">そんなときに便利なのが <strong>LET関数</strong> です。数式の中で「変数」を定義して、名前を付けて使い回せるようになります。</p>



<p class="wp-block-paragraph">この記事では、LET関数の基本構文から、実務で役立つ数式の整理テクニック、パフォーマンス改善の仕組みまでまとめて紹介します。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-2" checked><label class="toc-title" for="toc-checkbox-2">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">LET関数とは？</a></li><li><a href="#toc2" tabindex="0">LET関数の書き方（構文と引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">引数の説明</a></li></ol></li><li><a href="#toc5" tabindex="0">LET関数の基本的な使い方</a><ol><li><a href="#toc6" tabindex="0">変数を1つ定義する</a></li><li><a href="#toc7" tabindex="0">変数を複数定義する</a></li><li><a href="#toc8" tabindex="0">変数に数式の結果を代入する</a></li></ol></li><li><a href="#toc9" tabindex="0">LET関数の実践的な使い方・応用例</a><ol><li><a href="#toc10" tabindex="0">複雑なIF + VLOOKUP数式をLETで整理する</a></li><li><a href="#toc11" tabindex="0">IFERRORと組み合わせてエラーハンドリングする</a></li><li><a href="#toc12" tabindex="0">同じ計算を繰り返さずパフォーマンスを改善する</a></li><li><a href="#toc13" tabindex="0">FILTER関数と組み合わせる</a></li><li><a href="#toc14" tabindex="0">条件分岐をLETで見やすくする</a></li></ol></li><li><a href="#toc15" tabindex="0">よくあるエラーと対処法</a></li><li><a href="#toc16" tabindex="0">LAMBDA関数との違い・使い分け</a></li><li><a href="#toc17" tabindex="0">Googleスプレッドシートとの違い</a></li><li><a href="#toc18" tabindex="0">LET関数に関するよくある質問</a><ol><li><a href="#toc19" tabindex="0">定義した変数を別のセルから参照できますか？</a></li><li><a href="#toc20" tabindex="0">LET関数はスピル（動的配列）に対応していますか？</a></li><li><a href="#toc21" tabindex="0">VLOOKUPの代わりにXLOOKUPと組み合わせられますか？</a></li><li><a href="#toc22" tabindex="0">LET関数で速度が改善しない場合は？</a></li></ol></li><li><a href="#toc23" tabindex="0">まとめ</a><ol><li><a href="#toc24" tabindex="0">関連記事</a></li><li><a href="#toc25" tabindex="0">関数一覧</a></li></ol></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">LET関数とは？</span></h2>



<p class="wp-block-paragraph">LET関数（読み方: れっと）は、<strong>数式の中で変数を定義し、その変数を使って計算できる関数</strong>です。</p>



<p class="wp-block-paragraph">名前は英語の「let（〜を〜とする）」からきています。プログラミングでも変数宣言に使われるおなじみの単語ですね。</p>



<p class="wp-block-paragraph">たとえば <code>VLOOKUP(A2,B:D,3,FALSE)</code> の結果を何度も使いたいとします。LET関数で <code>price</code> という変数に入れておけば、数式の中で <code>price</code> と書くだけで参照できます。</p>



<p class="wp-block-paragraph">LET関数にできることをまとめると、次のとおりです。</p>



<ul class="wp-block-list"><li>数式の中で変数（名前と値のペア）を定義する</li><li>同じ計算を何度も書かずに済むので数式が短くなる</li><li>変数名を付けることで数式の意味が読み取りやすくなる</li><li>同じ計算は内部的に1回だけ実行されるのでパフォーマンスが向上する</li></ul>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>NOTE</strong></p><p>LET関数はMicrosoft 365、Excel 2021以降、Excel for the webで使えます。Excel 2019以前では #NAME? エラーになるので、お使いのバージョンを確認しておきましょう。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc2">LET関数の書き方（構文と引数）</span></h2>



<h3 class="wp-block-heading"><span id="toc3">基本構文</span></h3>



<pre class="wp-block-code"><code>=LET(名前1, 値1, [名前2, 値2, ...], 計算式)</code></pre>



<p class="wp-block-paragraph">「名前」と「値」をペアで指定し、最後に「計算式」を書きます。計算式の中で定義した名前を使えるのがポイントです。</p>



<h3 class="wp-block-heading"><span id="toc4">引数の説明</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/任意</th><th>説明</th></tr></thead><tbody><tr><td>名前1</td><td>必須</td><td>変数の名前。アルファベット・数字・アンダースコアで構成する</td></tr><tr><td>値1</td><td>必須</td><td>名前1に割り当てる値。セル参照・数式・直接値のいずれも可</td></tr><tr><td>名前2, 値2〜</td><td>任意</td><td>2組目以降の変数定義。最大126組まで指定可能</td></tr><tr><td>計算式</td><td>必須</td><td>定義した変数を使った計算式。最後の引数が計算式になる</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">変数名にはセル参照と同じ名前（A1やB2など）は使えません。<code>price</code> や <code>total</code> のように、中身がわかる名前を付けておくと読みやすくなりますよ。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>TIP</strong></p><p>引数の数は必ず <strong>奇数</strong> になります。「名前, 値」のペアが1組以上 + 最後の「計算式」で、最低3つです。偶数個を指定するとエラーになるので注意してください。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc5">LET関数の基本的な使い方</span></h2>



<p class="wp-block-paragraph">まずはシンプルな例で動きを確認してみましょう。</p>



<h3 class="wp-block-heading"><span id="toc6">変数を1つ定義する</span></h3>



<p class="wp-block-paragraph">税込価格を計算する例です。</p>



<pre class="wp-block-code"><code>=LET(tax, 1.1, A2 * tax)</code></pre>



<p class="wp-block-paragraph"><code>tax</code> という変数に <code>1.1</code> を代入し、A2に掛けています。A2が1000なら結果は <strong>1100</strong> です。</p>



<p class="wp-block-paragraph">この程度なら <code>=A2*1.1</code> でも十分ですが、数式が長くなると変数の効果が実感できます。</p>



<h3 class="wp-block-heading"><span id="toc7">変数を複数定義する</span></h3>



<p class="wp-block-paragraph">本体価格と税率をそれぞれ変数にして、税込価格を計算する例です。</p>



<pre class="wp-block-code"><code>=LET(price, A2, tax, 1.1, price * tax)</code></pre>



<p class="wp-block-paragraph"><code>price</code> にA2の値、<code>tax</code> に1.1を代入し、最後の <code>price * tax</code> で計算しています。</p>



<p class="wp-block-paragraph">変数を複数使うと「どの値が何を意味しているか」が明確になります。数式だけ見ても意味がわかるのがLET関数の大きなメリットですよ。</p>



<h3 class="wp-block-heading"><span id="toc8">変数に数式の結果を代入する</span></h3>



<p class="wp-block-paragraph">変数の「値」には数式を直接書くこともできます。</p>



<pre class="wp-block-code"><code>=LET(total, SUM(B2:B10), avg, total / COUNTA(B2:B10), avg)</code></pre>



<p class="wp-block-paragraph"><code>total</code> に合計値を代入し、<code>avg</code> に平均値を代入しています。<code>total</code> を <code>avg</code> の計算で再利用しているのがポイントです。</p>



<p class="wp-block-paragraph">このように、先に定義した変数を後の変数で使えるので、段階的に計算を組み立てられます。</p>



<h2 class="wp-block-heading"><span id="toc9">LET関数の実践的な使い方・応用例</span></h2>



<h3 class="wp-block-heading"><span id="toc10">複雑なIF + VLOOKUP数式をLETで整理する</span></h3>



<p class="wp-block-paragraph">LET関数が最も威力を発揮するのは、同じ計算が数式内で繰り返されるケースです。</p>



<p class="wp-block-paragraph"><strong>Before（LETなし）:</strong></p>



<pre class="wp-block-code"><code>=IF(VLOOKUP(A2,商品マスタ!A:C,3,FALSE)&gt;=1000, VLOOKUP(A2,商品マスタ!A:C,3,FALSE)*0.9, VLOOKUP(A2,商品マスタ!A:C,3,FALSE))</code></pre>



<p class="wp-block-paragraph">同じ <code>VLOOKUP</code> が3回も登場していて読みにくいですよね。</p>



<p class="wp-block-paragraph"><strong>After（LETあり）:</strong></p>



<pre class="wp-block-code"><code>=LET(price, VLOOKUP(A2,商品マスタ!A:C,3,FALSE), IF(price&gt;=1000, price*0.9, price))</code></pre>



<p class="wp-block-paragraph">VLOOKUPの結果を <code>price</code> に1回だけ代入しています。数式の長さが半分以下になり、何をしているかも一目でわかります。</p>



<h3 class="wp-block-heading"><span id="toc11">IFERRORと組み合わせてエラーハンドリングする</span></h3>



<p class="wp-block-paragraph">VLOOKUPのエラー処理をLET関数で整理する例です。</p>



<pre class="wp-block-code"><code>=LET(result, VLOOKUP(A2,商品マスタ!A:C,3,FALSE), IFERROR(result * 1.1, &quot;該当なし&quot;))</code></pre>



<p class="wp-block-paragraph">VLOOKUPの結果を <code>result</code> に入れておき、エラーなら「該当なし」、正常なら税込価格を返します。<a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>との組み合わせは実務で特によく使うパターンです。</p>



<h3 class="wp-block-heading"><span id="toc12">同じ計算を繰り返さずパフォーマンスを改善する</span></h3>



<p class="wp-block-paragraph">LET関数を使うと、変数に代入した計算は内部的に <strong>1回だけ</strong> 実行されます。</p>



<p class="wp-block-paragraph">たとえば先ほどのBefore版では、VLOOKUPが3回実行されます。対してAfter版のLET関数では1回で済みます。</p>



<p class="wp-block-paragraph">データ量が多いシートでは、この差が処理速度に影響してきます。数千行のデータでVLOOKUPやSUMIFSを繰り返している場合は要注意です。LET関数でまとめると、ブックの動作が軽くなることがありますよ。</p>



<h3 class="wp-block-heading"><span id="toc13">FILTER関数と組み合わせる</span></h3>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-function-howto-use-filter/">FILTER関数</a>の結果を変数に入れて、さらに加工する例です。</p>



<pre class="wp-block-code"><code>=LET(filtered, FILTER(A2:C20, B2:B20=&quot;東京&quot;), SORT(filtered, 3, -1))</code></pre>



<p class="wp-block-paragraph">東京のデータだけをFILTERで抽出し、その結果を3列目（たとえば売上）の降順でソートしています。</p>



<p class="wp-block-paragraph">FILTERとSORTを別々に書くと入れ子が深くなりますが、LET関数で段階的に処理すると読みやすくなります。</p>



<h3 class="wp-block-heading"><span id="toc14">条件分岐をLETで見やすくする</span></h3>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-function-howto-use-if/">IF関数</a>で複数条件を判定する数式をLETで整理する例です。</p>



<pre class="wp-block-code"><code>=LET(score, B2, IF(score&gt;=90, &quot;S&quot;, IF(score&gt;=70, &quot;A&quot;, IF(score&gt;=50, &quot;B&quot;, &quot;C&quot;))))</code></pre>



<p class="wp-block-paragraph">B2を <code>score</code> という変数に代入しています。ネストした<a href="https://mashukabu.com/excel-function-howto-use-ifs/">IFS関数</a>に書き換えることもできますが、LETで変数名を付けるだけでも何を判定しているかが明確になります。</p>



<h2 class="wp-block-heading"><span id="toc15">よくあるエラーと対処法</span></h2>



<p class="wp-block-paragraph">LET関数で「思った結果にならない」ケースをまとめました。</p>



<figure class="wp-block-table"><table><thead><tr><th>症状</th><th>原因</th><th>対処法</th></tr></thead><tbody><tr><td>#NAME? エラーが出る</td><td>変数名にセル参照と同じ名前（A1, B2など）を使っている</td><td>セル参照と重複しない名前に変更する（例: <code>val</code>, <code>x</code>）</td></tr><tr><td>#NAME? エラーが出る</td><td>Excel 2019以前を使っている</td><td>Microsoft 365またはExcel 2021以降にアップグレードする</td></tr><tr><td>#NAME? エラーが出る</td><td>変数名にスペースや記号を含めている</td><td>アルファベット・数字・アンダースコアのみ使用する</td></tr><tr><td>#VALUE! エラーが出る</td><td>引数の数が偶数になっている（計算式がない）</td><td>最後に計算式を追加する。引数の数は奇数が正しい</td></tr><tr><td>変数が認識されない</td><td>数式の中でスペルミスがある</td><td>変数名の大文字小文字を含めて正確に一致させる</td></tr><tr><td>数式が長いまま変わらない</td><td>LET関数の効果を誤解している</td><td>LET関数は数式の「見た目」を整理するもの。セルに表示される結果は変わらない</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">エラー値の詳細は<a href="https://mashukabu.com/excel-error-value-list/">Excelのエラー値一覧</a>も参考にしてください。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>TIP</strong></p><p>変数名はシンプルに短く付けるのがおすすめです。<code>x</code>, <code>val</code>, <code>price</code> のように意味がわかる最小限の名前にしておくと、数式全体が読みやすくなります。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc16">LAMBDA関数との違い・使い分け</span></h2>



<p class="wp-block-paragraph">LET関数と<a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA関数</a>はどちらも数式を整理できる関数ですが、役割が違います。</p>



<figure class="wp-block-table"><table><thead><tr><th>比較項目</th><th>LET関数</th><th>LAMBDA関数</th></tr></thead><tbody><tr><td>役割</td><td>数式の中で <strong>変数を定義</strong> する</td><td><strong>カスタム関数を定義</strong> する</td></tr><tr><td>使いどころ</td><td>同じ計算の繰り返しを減らす</td><td>よく使う計算ロジックを関数化する</td></tr><tr><td>再利用の範囲</td><td>そのセルの数式内のみ</td><td>「名前の管理」に登録すればブック全体</td></tr><tr><td>構文</td><td><code>=LET(名前, 値, 計算式)</code></td><td><code>=LAMBDA(引数, 数式)(値)</code></td></tr><tr><td>対応バージョン</td><td>Microsoft 365 / Excel 2021以降</td><td>Microsoft 365 / Excel 2024</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">使い分けのポイントは次のとおりです。</p>



<ul class="wp-block-list"><li><strong>「この数式の中で同じ計算を何度も書いている」</strong> → LET関数で変数にまとめる</li><li><strong>「この計算ロジックを他のセルやシートでも使い回したい」</strong> → LAMBDA関数で関数化する</li></ul>



<p class="wp-block-paragraph">両方を組み合わせることもできます。LAMBDA関数の中でLET関数を使えば、カスタム関数の内部でも変数を定義できますよ。</p>



<pre class="wp-block-code"><code>=LAMBDA(price, LET(tax, 1.1, discount, 0.9, price * tax * discount))(A2)</code></pre>



<h2 class="wp-block-heading"><span id="toc17">Googleスプレッドシートとの違い</span></h2>



<p class="wp-block-paragraph">GoogleスプレッドシートにもLET関数があり、基本的に同じ構文・同じ動作です。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>Excel</th><th>Googleスプレッドシート</th></tr></thead><tbody><tr><td>対応バージョン</td><td>Microsoft 365 / Excel 2021以降</td><td>全アカウント対応</td></tr><tr><td>構文</td><td><code>=LET(名前, 値, 計算式)</code></td><td><code>=LET(名前, 値, 計算式)</code></td></tr><tr><td>変数ペアの上限</td><td>126組</td><td>126組</td></tr><tr><td>パフォーマンス最適化</td><td>あり（1回だけ計算）</td><td>あり（1回だけ計算）</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">構文も動作もほぼ同じなので、Excelのファイルをスプレッドシートで開いてもLET関数はそのまま動作します。</p>



<h2 class="wp-block-heading"><span id="toc18">LET関数に関するよくある質問</span></h2>



<h3 class="wp-block-heading"><span id="toc19">定義した変数を別のセルから参照できますか？</span></h3>



<p class="wp-block-paragraph">できません。LET関数で定義した変数はそのセルの数式内だけで有効です。他のセルから参照する方法はありません。</p>



<p class="wp-block-paragraph">複数のセルで同じロジックを再利用したい場合は、<a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA関数</a>で「名前の管理」に登録するのがおすすめです。LAMBDA関数なら、ブック全体で共通の関数として使い回せます。</p>



<h3 class="wp-block-heading"><span id="toc20">LET関数はスピル（動的配列）に対応していますか？</span></h3>



<p class="wp-block-paragraph">対応しています。最後の計算式が配列を返すとき、結果はそのままスピル（溢れ表示）されます。</p>



<pre class="wp-block-code"><code>=LET(data, A2:A10, data * 1.1)</code></pre>



<p class="wp-block-paragraph">A2:A10の全値に1.1を掛けた配列が、下方向にスピルして表示されます。<a href="https://mashukabu.com/excel-function-howto-use-filter/">FILTER関数</a>や<a href="https://mashukabu.com/excel-function-howto-use-sort/">SORT関数</a>と組み合わせて動的配列を処理するときも、LET関数の変数にそのまま入れて使えます。</p>



<h3 class="wp-block-heading"><span id="toc21">VLOOKUPの代わりにXLOOKUPと組み合わせられますか？</span></h3>



<p class="wp-block-paragraph">使えます。XLOOKUPはVLOOKUPより高機能なため、LET関数との組み合わせも同様に機能します。</p>



<pre class="wp-block-code"><code>=LET(price, XLOOKUP(A2, 商品マスタ!A:A, 商品マスタ!C:C, &quot;該当なし&quot;), IF(price=&quot;該当なし&quot;, price, price*1.1))</code></pre>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-function-howto-use-xlookup/">XLOOKUP関数</a>は検索列と戻り列を別々に指定できるため、列番号を数えるミスがなくなります。VLOOKUPをLETで使っている数式は、XLOOKUPに差し替えるとさらに読みやすくなりますよ。</p>



<h3 class="wp-block-heading"><span id="toc22">LET関数で速度が改善しない場合は？</span></h3>



<p class="wp-block-paragraph">定義した変数を計算式の中で1回しか使っていない場合は、パフォーマンス上のメリットはありません。速度改善の効果が出るのは、同じ計算を2回以上使うケースです。</p>



<pre class="wp-block-code"><code>× 速度改善なし（変数を1回しか使っていない）
=LET(x, SUM(A2:A100), x)

○ 速度改善あり（変数を2回以上使っている）
=LET(total, SUM(A2:A100), avg, total/COUNTA(A2:A100), avg)</code></pre>



<p class="wp-block-paragraph">数式の見通しをよくするためだけにLET関数を使うことも十分意味があります。速度改善を狙うなら、同じ計算が2回以上登場するケースを意識して変数にまとめてください。</p>



<h2 class="wp-block-heading"><span id="toc23">まとめ</span></h2>



<p class="wp-block-paragraph">LET関数は、数式の中で変数を定義して再利用できる関数です。</p>



<p class="wp-block-paragraph">ポイントを整理します。</p>



<ul class="wp-block-list"><li>構文は <code>=LET(名前, 値, 計算式)</code> で、名前と値をペアで指定する</li><li>同じ計算を何度も書かなくて済むので、数式が短くなる</li><li>変数名を付けることで、数式の意味が読み取りやすくなる</li><li>同じ計算は内部的に1回だけ実行されるため、パフォーマンスも向上する</li><li>引数の数は必ず奇数。偶数だとエラーになる</li><li>変数名にセル参照と同じ名前（A1など）は使えない</li><li><a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA関数</a>は「関数を定義」、LET関数は「変数を定義」と覚えると使い分けやすい</li></ul>



<p class="wp-block-paragraph">まずは <code>=LET(x, 10, x*2)</code> で「変数xに10を入れて2倍 = 20」から試してみてください。</p>



<hr class="wp-block-separator has-alpha-channel-opacity"/>



<h3 class="wp-block-heading"><span id="toc24">関連記事</span></h3>



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA関数の使い方</a></li><li><a href="https://mashukabu.com/excel-function-howto-use-filter/">FILTER関数の使い方</a></li><li><a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数の使い方</a></li><li><a href="https://mashukabu.com/excel-function-howto-use-if/">IF関数の使い方</a></li></ul>



<h3 class="wp-block-heading"><span id="toc25">関数一覧</span></h3>



<p class="wp-block-paragraph">Excel関数の一覧は下記の記事で確認できます。</p>



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-function-list-by-function/">Excel関数 機能別一覧</a></li></ul>



<p class="wp-block-paragraph">エラー値が表示される場合は、下記の記事も参考にしてみてください。</p>



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-error-value-list/">Excelのエラー値一覧</a></li></ul>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-let/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
