<?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>Thu, 07 May 2026 12:43:18 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</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 と組み合わせて省略可能引数を作る方法、ISBLANK との違い、対応バージョンや #CALC! エラーの原因まで実務目線で解説します。]]></description>
										<content:encoded><![CDATA[
<p>「ExcelのISOMITTED関数って何ができるの？」「LAMBDAで作った自作関数の引数を省略できるようにしたい」。そんな疑問はありませんか？</p>



<p>ISOMITTED関数（読み方：イズオミッティッド）は、LAMBDA関数の引数が省略されたかを判定する関数です。関数名は「IS（〜である）+ OMITTED（省略された）」に由来します。IFと組み合わせれば、引数を省略したときに既定値を返す「省略可能引数つきカスタム関数」をVBAなしで作れます。</p>



<p>この記事では、ISOMITTED関数の基本構文と使い方を解説します。LAMBDA + IF を使った省略引数の実装、複数引数の省略チェック、名前付き関数としての保存、ISBLANK関数との違い、対応バージョンやよくあるエラーの対処法までカバーします。</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">名前付き関数として保存して再利用する</a><ol><li><a href="#toc14" tabindex="0">保存手順</a></li><li><a href="#toc15" tabindex="0">使い方</a></li><li><a href="#toc16" tabindex="0">注意点</a></li></ol></li><li><a href="#toc17" tabindex="0">ISOMITTED関数とISBLANK関数の違い・使い分け</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関数のよくあるエラーと対処法</a><ol><li><a href="#toc22" tabindex="0">#NAME? エラー</a></li><li><a href="#toc23" tabindex="0">#CALC! エラー</a></li><li><a href="#toc24" tabindex="0">#VALUE! エラー</a></li></ol></li><li><a href="#toc25" tabindex="0">まとめ｜ISOMITTED関数で省略可能引数つきカスタム関数を作る</a></li></ol>
    </div>
  </div>

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



<p>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>ポイントは、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>Excel 2021 以前のバージョンでは使えません。<code>#NAME?</code> エラーになります。LAMBDA関数自体が Microsoft 365 と Excel 2024 で導入された機能です。ISOMITTEDもそれに準じます。</p>



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



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



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



<p>税込価格を計算する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>第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>第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>このように、引数の省略可否をISOMITTEDで判定し、IFで既定値と明示値を切り替えるのが基本パターンです。</p>



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



<p>複数の引数をそれぞれ独立して省略可能にすることもできます。各引数ごとに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>第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>第3引数だけ <code>-</code> を指定します。結果は <code>Excel-関数</code> になります。第4引数は省略のままなので、接頭辞は付きません。</p>



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



<p>LET関数で中間変数（<code>s</code>, <code>p</code>）を定義することで、IFの分岐結果を一度だけ計算して再利用できます。可読性も上がるため、LAMBDA + ISOMITTEDの組み合わせではLETを併用するのが定石です。</p>



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



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



<h3 class="wp-block-heading"><span id="toc14">保存手順</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="toc15">使い方</span></h3>



<p>保存後は、ワークブック全体で次のように使えます。</p>



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



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



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



<ul class="wp-block-list"><li>名前付き関数はワークブック単位で保存されます。別ファイルでは使えません</li><li>共有する場合はテンプレートとして配布するか、相手にも同じ名前付き関数を作成してもらう必要があります</li></ul>



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



<p>ISOMITTEDと似た判定をする関数にISBLANKがあります。役割がまったく異なるため、混同しないよう整理しておきます。</p>



<h3 class="wp-block-heading"><span id="toc18">機能の比較</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="toc19">動作の違い（具体例）</span></h3>



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



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



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



<p>一方、ISBLANKで同じ判定をすると次のようになります。</p>



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



<p>A1 が空白なら ISBLANKは <code>TRUE</code>（空セル）を返します。</p>



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



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



<p>両方を組み合わせて「省略 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="toc21">ISOMITTED関数のよくあるエラーと対処法</span></h2>



<p>ISOMITTEDでエラーが出やすいケースと対処法をまとめます。</p>



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



<p><strong>原因</strong>: ExcelのバージョンがISOMITTEDに対応していない</p>



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



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



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



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



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



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



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



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



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



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



<p>第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="toc25">まとめ｜ISOMITTED関数で省略可能引数つきカスタム関数を作る</span></h2>



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



<p>ポイントを整理します。</p>



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



<p>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>
