<?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>関数自作 &#8211; biz-tactics</title>
	<atom:link href="https://mashukabu.com/tag/%e9%96%a2%e6%95%b0%e8%87%aa%e4%bd%9c/feed/" rel="self" type="application/rss+xml" />
	<link>https://mashukabu.com</link>
	<description></description>
	<lastBuildDate>Sun, 17 May 2026 00:13:08 +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>関数自作 &#8211; biz-tactics</title>
	<link>https://mashukabu.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>ExcelのISOMITTED関数の使い方｜LAMBDAの省略引数を判定して既定値を返す</title>
		<link>https://mashukabu.com/excel-function-howto-use-isomitted/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-isomitted/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Thu, 07 May 2026 12:43:18 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[Excel]]></category>
		<category><![CDATA[LAMBDA]]></category>
		<category><![CDATA[LET]]></category>
		<category><![CDATA[Microsoft 365]]></category>
		<category><![CDATA[関数自作]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=6584</guid>

					<description><![CDATA[ExcelのISOMITTED関数は、LAMBDAで定義した引数が省略されたかをTRUE/FALSEで返す関数です。基本構文、IFと組み合わせて省略可能引数つきカスタム関数を作る方法、LET・MAP・REDUCEとの連携、ISBLANKとの違い、対応バージョンや#CALC!エラーの原因まで実務目線で丁寧に解説します。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">「ExcelのISOMITTED関数って何ができるの？」「LAMBDAで作った自作関数の引数を省略できるようにしたい」。そんな疑問はありませんか？</p>



<p class="wp-block-paragraph">ISOMITTED関数（読み方：イズオミッティッド）は、<a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA関数</a>の引数が省略されたかを判定する関数です。関数名は「IS（〜である）+ OMITTED(省略された)」に由来します。IFと組み合わせれば、引数を省略したときに既定値を返す「省略可能引数つきカスタム関数」をVBAなしで作れます。</p>



<p class="wp-block-paragraph">この記事では、ISOMITTED関数の基本構文と使い方を解説します。LAMBDA + IF を使った省略引数の実装、複数引数の省略チェック、<a href="https://mashukabu.com/excel-function-howto-use-let/">LET関数</a>との組み合わせ、名前付き関数としての保存、<a href="https://mashukabu.com/excel-function-howto-use-isblank/">ISBLANK関数</a>との違い、<a href="https://mashukabu.com/excel-function-howto-use-map/">MAP関数</a>や<a href="https://mashukabu.com/excel-function-howto-use-reduce/">REDUCE関数</a>との組み合わせ、対応バージョンやよくあるエラーの対処法、実務でよくある質問までカバーします。</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">ISOMITTED関数とは？LAMBDAの引数省略を判定するExcel関数</a><ol><li><a href="#toc2" tabindex="0">構文</a></li><li><a href="#toc3" tabindex="0">戻り値</a></li><li><a href="#toc4" tabindex="0">対応バージョン</a></li></ol></li><li><a href="#toc5" tabindex="0">ISOMITTED関数の基本的な使い方｜IFと組み合わせて既定値を返す</a><ol><li><a href="#toc6" tabindex="0">例: 税込価格を計算するカスタム関数</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">複数の引数を省略可能にする実務パターン</a><ol><li><a href="#toc10" tabindex="0">例: 文字列を結合するカスタム関数（区切り文字と接頭辞をオプションに）</a></li><li><a href="#toc11" tabindex="0">引数を一部だけ指定する場合</a></li><li><a href="#toc12" tabindex="0">LET と組み合わせる利点</a></li></ol></li><li><a href="#toc13" tabindex="0">実務で使える応用パターン3選</a><ol><li><a href="#toc14" tabindex="0">パターン1: 端数処理の方法を選べる丸め関数</a></li><li><a href="#toc15" tabindex="0">パターン2: 範囲の合計に「条件」と「割引率」を後付けできる関数</a></li><li><a href="#toc16" tabindex="0">パターン3: MAP・REDUCEと組み合わせて配列処理を柔軟にする</a></li></ol></li><li><a href="#toc17" tabindex="0">名前付き関数として保存して再利用する</a><ol><li><a href="#toc18" tabindex="0">保存手順</a></li><li><a href="#toc19" tabindex="0">使い方</a></li><li><a href="#toc20" tabindex="0">注意点</a></li></ol></li><li><a href="#toc21" tabindex="0">ISOMITTED関数とISBLANK関数の違い・使い分け</a><ol><li><a href="#toc22" tabindex="0">機能の比較</a></li><li><a href="#toc23" tabindex="0">動作の違い（具体例）</a></li><li><a href="#toc24" tabindex="0">使い分けの基準</a></li></ol></li><li><a href="#toc25" tabindex="0">ISOMITTED関数のよくあるエラーと対処法</a><ol><li><a href="#toc26" tabindex="0">#NAME? エラー</a></li><li><a href="#toc27" tabindex="0">#CALC! エラー</a></li><li><a href="#toc28" tabindex="0">#VALUE! エラー</a></li></ol></li><li><a href="#toc29" tabindex="0">よくある質問（FAQ）</a><ol><li><a href="#toc30" tabindex="0">Q1. ISOMITTEDは省略できる引数の「位置」に制限はありますか？</a></li><li><a href="#toc31" tabindex="0">Q2. ISOMITTEDをIFS関数やSWITCH関数と組み合わせても問題ありませんか？</a></li><li><a href="#toc32" tabindex="0">Q3. ISOMITTEDで判定したあと、未指定の引数に「セルの値」を既定値として使うことはできますか？</a></li></ol></li><li><a href="#toc33" tabindex="0">まとめ｜ISOMITTED関数で省略可能引数つきカスタム関数を作る</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">ISOMITTED関数とは？LAMBDAの引数省略を判定するExcel関数</span></h2>



<p class="wp-block-paragraph">ISOMITTED関数は、LAMBDA関数の引数が省略されたかどうかを <code>TRUE</code> / <code>FALSE</code> で返す関数です。LAMBDA関数の中でしか意味を持たない、特殊な用途の関数です。</p>



<h3 class="wp-block-heading"><span id="toc2">構文</span></h3>



<pre class="wp-block-code"><code>=ISOMITTED(argument)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>説明</th></tr></thead><tbody><tr><td>argument</td><td>LAMBDA関数の引数。チェックしたい引数名をそのまま渡す</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc3">戻り値</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>状態</th><th>戻り値</th></tr></thead><tbody><tr><td>引数が省略されている</td><td><code>TRUE</code></td></tr><tr><td>引数が指定されている</td><td><code>FALSE</code></td></tr></tbody></table></figure>



<p class="wp-block-paragraph">ポイントは、ISOMITTEDは <strong>LAMBDA関数の引数に対してのみ</strong> 動作することです。通常のセル参照（例: <code>=ISOMITTED(A1)</code>）に対して使っても、正しい結果は返りません。<code>#CALC!</code> エラーや <code>FALSE</code> 固定になります。</p>



<h3 class="wp-block-heading"><span id="toc4">対応バージョン</span></h3>



<ul class="wp-block-list"><li>Microsoft 365（Windows / Mac / Web）</li><li>Excel 2024（永続ライセンス版）</li><li>Excel for the web</li></ul>



<p class="wp-block-paragraph">Excel 2021 以前のバージョンでは使えません。<code>#NAME?</code> エラーになります。LAMBDA関数自体が Microsoft 365 と Excel 2024 で導入された機能です。ISOMITTEDもそれに準じます。LAMBDAやLETの基礎から学びたい方は、<a href="https://mashukabu.com/excel-let-lambda-function-guide/">LET・LAMBDA関数で自作関数を作る完全ガイド</a>も参考になります。</p>



<h2 class="wp-block-heading"><span id="toc5">ISOMITTED関数の基本的な使い方｜IFと組み合わせて既定値を返す</span></h2>



<p class="wp-block-paragraph">ISOMITTED関数の最も基本的な使い方は、IF関数との組み合わせです。「引数が省略されたら既定値を使う」というパターンを実装します。</p>



<h3 class="wp-block-heading"><span id="toc6">例: 税込価格を計算するカスタム関数</span></h3>



<p class="wp-block-paragraph">税込価格を計算するLAMBDA関数を作ります。第2引数の税率を省略したら自動で 10% を適用する仕様にします。</p>



<pre class="wp-block-code"><code>=LAMBDA(price,rate,
  IF(ISOMITTED(rate), price*1.10, price*(1+rate))
)(1000)</code></pre>



<p class="wp-block-paragraph">第2引数 <code>rate</code> を省略しているので、<code>ISOMITTED(rate)</code> が <code>TRUE</code> を返します。IFの分岐により <code>1000*1.10 = 1100</code> が結果として返ります。</p>



<h3 class="wp-block-heading"><span id="toc7">例: 税率を明示的に渡す場合</span></h3>



<pre class="wp-block-code"><code>=LAMBDA(price,rate,
  IF(ISOMITTED(rate), price*1.10, price*(1+rate))
)(1000, 0.08)</code></pre>



<p class="wp-block-paragraph">第2引数に <code>0.08</code>（8%）を渡しています。<code>ISOMITTED(rate)</code> は <code>FALSE</code> を返すため、IFの偽の側 <code>1000*1.08 = 1080</code> が結果になります。</p>



<h3 class="wp-block-heading"><span id="toc8">結果の比較</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>数式</th><th>結果</th></tr></thead><tbody><tr><td><code>=LAMBDA(price,rate, IF(ISOMITTED(rate), price<em>1.10, price</em>(1+rate)))(1000)</code></td><td>1100</td></tr><tr><td><code>=LAMBDA(price,rate, IF(ISOMITTED(rate), price<em>1.10, price</em>(1+rate)))(1000, 0.08)</code></td><td>1080</td></tr><tr><td><code>=LAMBDA(price,rate, IF(ISOMITTED(rate), price<em>1.10, price</em>(1+rate)))(1000, 0.05)</code></td><td>1050</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">このように、引数の省略可否をISOMITTEDで判定し、IFで既定値と明示値を切り替えるのが基本パターンです。</p>



<h2 class="wp-block-heading"><span id="toc9">複数の引数を省略可能にする実務パターン</span></h2>



<p class="wp-block-paragraph">複数の引数をそれぞれ独立して省略可能にすることもできます。各引数ごとにISOMITTEDで個別にチェックし、IFで分岐します。</p>



<h3 class="wp-block-heading"><span id="toc10">例: 文字列を結合するカスタム関数（区切り文字と接頭辞をオプションに）</span></h3>



<pre class="wp-block-code"><code>=LAMBDA(text1,text2,sep,prefix,
  LET(
    s, IF(ISOMITTED(sep), &quot; &quot;, sep),
    p, IF(ISOMITTED(prefix), &quot;&quot;, prefix),
    p &amp; text1 &amp; s &amp; text2
  )
)(&quot;Excel&quot;,&quot;関数&quot;)</code></pre>



<p class="wp-block-paragraph">第3引数 <code>sep</code>（区切り文字）と第4引数 <code>prefix</code>（接頭辞）を両方省略すると、半角スペース区切り・接頭辞なしで結合されます。結果は <code>Excel 関数</code> になります。</p>



<h3 class="wp-block-heading"><span id="toc11">引数を一部だけ指定する場合</span></h3>



<pre class="wp-block-code"><code>=LAMBDA(text1,text2,sep,prefix,
  LET(
    s, IF(ISOMITTED(sep), &quot; &quot;, sep),
    p, IF(ISOMITTED(prefix), &quot;&quot;, prefix),
    p &amp; text1 &amp; s &amp; text2
  )
)(&quot;Excel&quot;,&quot;関数&quot;,&quot;-&quot;)</code></pre>



<p class="wp-block-paragraph">第3引数だけ <code>-</code> を指定します。結果は <code>Excel-関数</code> になります。第4引数は省略のままなので、接頭辞は付きません。</p>



<h3 class="wp-block-heading"><span id="toc12">LET と組み合わせる利点</span></h3>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-function-howto-use-let/">LET関数</a>で中間変数（<code>s</code>, <code>p</code>）を定義することで、IFの分岐結果を一度だけ計算して再利用できます。可読性も上がるため、LAMBDA + ISOMITTEDの組み合わせではLETを併用するのが定石です。</p>



<h2 class="wp-block-heading"><span id="toc13">実務で使える応用パターン3選</span></h2>



<p class="wp-block-paragraph">ISOMITTEDは、ちょっとした自作関数を「使いやすく」するのに非常に有効です。実務でよく使う応用パターンを3つ紹介します。</p>



<h3 class="wp-block-heading"><span id="toc14">パターン1: 端数処理の方法を選べる丸め関数</span></h3>



<p class="wp-block-paragraph">金額計算で「四捨五入・切り上げ・切り捨て」を切り替えたい場面は多いです。第2引数を省略したら四捨五入、<code>"up"</code> / <code>"down"</code> を指定したらそれぞれ切り上げ・切り捨てにする関数を作ります。</p>



<pre class="wp-block-code"><code>=LAMBDA(value,mode,
  LET(
    m, IF(ISOMITTED(mode), &quot;round&quot;, mode),
    IF(m=&quot;up&quot;, ROUNDUP(value,0),
      IF(m=&quot;down&quot;, ROUNDDOWN(value,0), ROUND(value,0)))
  )
)(1234.5,&quot;up&quot;)</code></pre>



<p class="wp-block-paragraph"><code>1234.5</code> を切り上げて <code>1235</code> を返します。省略時は四捨五入になるので、普段使いは <code>=丸め(1234.5)</code> で済みます。</p>



<h3 class="wp-block-heading"><span id="toc15">パターン2: 範囲の合計に「条件」と「割引率」を後付けできる関数</span></h3>



<p class="wp-block-paragraph">販売データから合計金額を出すとき、「特定の商品だけ集計したい」「割引率を後から差し込みたい」というニーズがあります。両方を省略可能にしておくと、1つの関数で複数のレポートに使い回せます。</p>



<pre class="wp-block-code"><code>=LAMBDA(amounts,product_col,product_name,discount,
  LET(
    base, IF(ISOMITTED(product_col), SUM(amounts),
              SUMIF(product_col, product_name, amounts)),
    rate, IF(ISOMITTED(discount), 0, discount),
    base * (1 - rate)
  )
)(B2:B100, A2:A100, &quot;Excel本&quot;, 0.1)</code></pre>



<p class="wp-block-paragraph">商品列・商品名を省略すれば全合計、指定すれば商品別合計、さらに割引率を渡せば適用後の金額が出ます。</p>



<h3 class="wp-block-heading"><span id="toc16">パターン3: MAP・REDUCEと組み合わせて配列処理を柔軟にする</span></h3>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-function-howto-use-map/">MAP関数</a>や<a href="https://mashukabu.com/excel-function-howto-use-reduce/">REDUCE関数</a>に渡すLAMBDA内でもISOMITTEDは使えます。たとえば「配列の各要素に係数をかけるが、係数を省略したら何もしない」関数です。</p>



<pre class="wp-block-code"><code>=LAMBDA(arr,factor,
  MAP(arr, LAMBDA(x,
    IF(ISOMITTED(factor), x, x*factor)
  ))
)(A1:A5, 2)</code></pre>



<p class="wp-block-paragraph"><code>A1:A5</code> の各値を2倍にして返します。第2引数を省略すれば元の値をそのまま返すので、テスト用と本番用で同じ関数が使えます。配列全体をスキャンするなら<a href="https://mashukabu.com/excel-function-howto-use-scan/">SCAN関数</a>、行・列単位で処理するなら<a href="https://mashukabu.com/excel-function-howto-use-byrow/">BYROW関数</a>・<a href="https://mashukabu.com/excel-function-howto-use-bycol/">BYCOL関数</a>と組み合わせるのも有効です。</p>



<h2 class="wp-block-heading"><span id="toc17">名前付き関数として保存して再利用する</span></h2>



<p class="wp-block-paragraph">LAMBDA + ISOMITTEDで作った関数は、Excelの「名前の管理」機能で名前を付けて保存できます。保存後は普通の関数のように使えます。</p>



<h3 class="wp-block-heading"><span id="toc18">保存手順</span></h3>



<ol class="wp-block-list"><li>リボンの「数式」タブ →「名前の管理」→「新規作成」をクリック</li><li>「名前」欄に関数名を入力（例: <code>税込価格</code>）</li><li>「参照範囲」欄に LAMBDA 式を入力</li></ol>



<pre class="wp-block-code"><code>   =LAMBDA(price,rate, IF(ISOMITTED(rate), price*1.10, price*(1+rate)))</code></pre>



<ol class="wp-block-list"><li>「OK」をクリックして保存</li></ol>



<h3 class="wp-block-heading"><span id="toc19">使い方</span></h3>



<p class="wp-block-paragraph">保存後は、ワークブック全体で次のように使えます。</p>



<pre class="wp-block-code"><code>=税込価格(1000)
=税込価格(1000, 0.08)</code></pre>



<p class="wp-block-paragraph">第2引数は省略可能です。省略時は 10%、指定時はその税率が使われます。VBAでユーザー定義関数を作る場合と比べて、配布が簡単です。ファイルに埋め込まれるため、セキュリティ警告も出ません。</p>



<h3 class="wp-block-heading"><span id="toc20">注意点</span></h3>



<ul class="wp-block-list"><li>名前付き関数はワークブック単位で保存されます。別ファイルでは使えません</li><li>共有する場合はテンプレートとして配布するか、相手にも同じ名前付き関数を作成してもらう必要があります</li><li>名前付き関数の作り方の全体像は<a href="https://mashukabu.com/excel-let-lambda-function-guide/">LET・LAMBDA関数で自作関数を作る完全ガイド</a>で詳しく紹介しています</li></ul>



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



<p class="wp-block-paragraph">ISOMITTEDと似た判定をする関数に<a href="https://mashukabu.com/excel-function-howto-use-isblank/">ISBLANK関数</a>があります。役割がまったく異なるため、混同しないよう整理しておきます。</p>



<h3 class="wp-block-heading"><span id="toc22">機能の比較</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>判定対象</th><th>使える場所</th></tr></thead><tbody><tr><td>ISOMITTED</td><td>LAMBDAの引数が省略されたか</td><td>LAMBDA関数の本体内のみ</td></tr><tr><td>ISBLANK</td><td>セルが空白（未入力）か</td><td>通常の数式すべて</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc23">動作の違い（具体例）</span></h3>



<p class="wp-block-paragraph">セル A1 が空白の状態で、次の自作関数を呼び出します。</p>



<pre class="wp-block-code"><code>=LAMBDA(x, IF(ISOMITTED(x), &quot;省略&quot;, &quot;指定あり&quot;))(A1)</code></pre>



<p class="wp-block-paragraph">引数 <code>x</code> には A1 の参照が渡されています。そのためISOMITTEDは <code>FALSE</code>（指定あり）を返します。A1 が空白セルでも、引数として渡されている以上「省略されていない」と判定されます。</p>



<p class="wp-block-paragraph">一方、ISBLANKで同じ判定をすると次のようになります。</p>



<pre class="wp-block-code"><code>=LAMBDA(x, IF(ISBLANK(x), &quot;空セル&quot;, &quot;値あり&quot;))(A1)</code></pre>



<p class="wp-block-paragraph">A1 が空白なら ISBLANKは <code>TRUE</code>（空セル）を返します。</p>



<h3 class="wp-block-heading"><span id="toc24">使い分けの基準</span></h3>



<ul class="wp-block-list"><li>「引数自体が渡されたか」を判定したい → ISOMITTED</li><li>「渡された引数の中身が空白か」を判定したい → ISBLANK</li></ul>



<p class="wp-block-paragraph">両方を組み合わせて「省略 or 空セルなら既定値」とすることもできます。</p>



<pre class="wp-block-code"><code>=LAMBDA(x,
  IF(OR(ISOMITTED(x), ISBLANK(x)), &quot;デフォルト値&quot;, x)
)</code></pre>



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



<p class="wp-block-paragraph">ISOMITTEDでエラーが出やすいケースと対処法をまとめます。</p>



<h3 class="wp-block-heading"><span id="toc26">#NAME? エラー</span></h3>



<p class="wp-block-paragraph"><strong>原因</strong>: ExcelのバージョンがISOMITTEDに対応していない</p>



<p class="wp-block-paragraph"><strong>対処法</strong>: Microsoft 365 または Excel 2024 にアップグレードします。Excel 2021 以前では使用できません。会社の環境でアップグレードできない場合は、VBAでユーザー定義関数を作る方法を検討してください。</p>



<h3 class="wp-block-heading"><span id="toc27">#CALC! エラー</span></h3>



<p class="wp-block-paragraph"><strong>原因</strong>: ISOMITTEDをLAMBDAの外で使った、またはLAMBDA引数以外の値に対して使った</p>



<p class="wp-block-paragraph"><strong>対処法</strong>: ISOMITTEDは必ずLAMBDA関数の本体内で使ってください。対象は、そのLAMBDAで定義した引数名に限定されます。</p>



<pre class="wp-block-code"><code>=ISOMITTED(A1)</code></pre>



<p class="wp-block-paragraph">このような書き方は動作しません（A1はLAMBDAの引数ではないため）。</p>



<h3 class="wp-block-heading"><span id="toc28">#VALUE! エラー</span></h3>



<p class="wp-block-paragraph"><strong>原因</strong>: LAMBDA本体の処理が、省略された引数を計算に使ってしまっている</p>



<p class="wp-block-paragraph"><strong>対処法</strong>: ISOMITTEDで先に分岐させ、省略時は引数を直接参照しないようにします。次の例ではエラーになります。</p>



<pre class="wp-block-code"><code>=LAMBDA(price,rate, price*(1+rate))(1000)</code></pre>



<p class="wp-block-paragraph">第2引数 <code>rate</code> を省略しているのに、本体で <code>rate</code> を計算に使っているためエラーになります。ISOMITTEDで先にチェックする形に書き換えてください。</p>



<pre class="wp-block-code"><code>=LAMBDA(price,rate, IF(ISOMITTED(rate), price*1.10, price*(1+rate)))(1000)</code></pre>



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



<h3 class="wp-block-heading"><span id="toc30">Q1. ISOMITTEDは省略できる引数の「位置」に制限はありますか？</span></h3>



<p class="wp-block-paragraph">第1引数だけ省略して第2引数を指定する、といった「途中省略」はできません。Excelの関数呼び出しは位置引数のため、後ろから順に省略するのが基本です。<code>=関数(値1,,値3)</code> のように途中の引数だけ空にすると、<code>#VALUE!</code> エラーや想定外の挙動になることがあります。実務的には「省略可能にしたい引数は末尾に並べる」のが安全な設計です。</p>



<h3 class="wp-block-heading"><span id="toc31">Q2. ISOMITTEDをIFS関数やSWITCH関数と組み合わせても問題ありませんか？</span></h3>



<p class="wp-block-paragraph">問題ありません。IFを多段にネストすると可読性が落ちるため、分岐が3つ以上ある場合はIFSやSWITCHのほうがすっきり書けます。たとえば「引数が省略 → A、<code>"high"</code> → B、<code>"low"</code> → C」のような分岐は、<code>IFS(ISOMITTED(x), A, x="high", B, x="low", C)</code> の形で素直に表現できます。</p>



<h3 class="wp-block-heading"><span id="toc32">Q3. ISOMITTEDで判定したあと、未指定の引数に「セルの値」を既定値として使うことはできますか？</span></h3>



<p class="wp-block-paragraph">できます。LAMBDA本体で、IFの真側に直接セル参照を書けば、省略時にそのセル値が使われます。たとえば <code>IF(ISOMITTED(rate), Sheet1!$B$1, rate)</code> のように書くと、<code>Sheet1!$B$1</code> に入っている既定税率が省略時の値になります。設定値を1か所にまとめておくと、後からの変更が楽になります。</p>



<h2 class="wp-block-heading"><span id="toc33">まとめ｜ISOMITTED関数で省略可能引数つきカスタム関数を作る</span></h2>



<p class="wp-block-paragraph">ExcelのISOMITTED関数は、LAMBDA関数で定義した引数が省略されたかを <code>TRUE</code> / <code>FALSE</code> で返す関数です。IF関数と組み合わせれば、引数を省略したときに既定値を返す「省略可能引数つきカスタム関数」をVBAなしで作れます。</p>



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



<ul class="wp-block-list"><li>ISOMITTEDはLAMBDAの引数に対してのみ動作する（通常セル参照には使えない）</li><li>基本パターンは <code>IF(ISOMITTED(引数), 既定値, 通常処理)</code></li><li>複数の引数を独立して省略チェックできる（<a href="https://mashukabu.com/excel-function-howto-use-let/">LET</a>と組み合わせるのが定石）</li><li><a href="https://mashukabu.com/excel-function-howto-use-map/">MAP</a>・<a href="https://mashukabu.com/excel-function-howto-use-reduce/">REDUCE</a>・<a href="https://mashukabu.com/excel-function-howto-use-scan/">SCAN</a>など配列処理関数とも相性がよい</li><li>「名前の管理」で<a href="https://mashukabu.com/excel-function-howto-use-lambda/">LAMBDA</a>に名前を付ければ、再利用可能なカスタム関数になる</li><li><a href="https://mashukabu.com/excel-function-howto-use-isblank/">ISBLANK</a>との違い: ISOMITTEDは「引数が渡されたか」、ISBLANKは「中身が空白か」を判定する</li><li>対応バージョンはMicrosoft 365とExcel 2024のみ</li></ul>



<p class="wp-block-paragraph">LAMBDA関数でカスタム関数を作るとき、ISOMITTEDを使えば実用性が一段上がります。VBAに頼らずExcelだけで柔軟な自作関数を組みたい場面で活躍する関数です。ぜひ一度試してみてください。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-isomitted/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
