<?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>FIND関数 &#8211; biz-tactics</title>
	<atom:link href="https://mashukabu.com/tag/find%e9%96%a2%e6%95%b0/feed/" rel="self" type="application/rss+xml" />
	<link>https://mashukabu.com</link>
	<description></description>
	<lastBuildDate>Sat, 18 Apr 2026 09:03:28 +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>FIND関数 &#8211; biz-tactics</title>
	<link>https://mashukabu.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>ExcelのFIND関数の使い方｜文字位置を検索して文字列を抽出する</title>
		<link>https://mashukabu.com/excel-function-howto-use-find/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-find/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 18 Apr 2026 09:03:28 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[SEARCH関数との違い]]></category>
		<category><![CDATA[エラー回避]]></category>
		<category><![CDATA[文字列抽出]]></category>
		<category><![CDATA[文字列操作]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=6048</guid>

					<description><![CDATA[ExcelのFIND関数の使い方を基本から解説。SEARCH関数との違い（大文字小文字区別・ワイルドカード可否）を比較表で即決。LEFT/MID/RIGHTとの組み合わせで商品コード・メールアドレスを実務的に抽出する方法と、IFERRORでエラーを回避するテクニックを紹介します。]]></description>
										<content:encoded><![CDATA[
<p>Excelで「商品コードのハイフンが何文字目にあるか調べたい」「メールアドレスの@の位置を取って、その前後を切り出したい」と思ったことはありませんか？ LEFT・MID・RIGHT関数は知っていても、「切り出し位置を自動で判定する」までつながらないと、結局セルごとに手作業で文字数を数える羽目になりますよね。</p>



<p>そんなときに使えるのが <strong>FIND関数</strong>（ファインド関数）です。 FIND（ファインド）は英語で「見つける」を意味し、指定した文字が何文字目にあるかを返してくれます。 返した位置をLEFT・MID・RIGHTの引数にそのまま渡せば、商品コード・メールアドレス・カッコ付き文字列を一発で分解できます。</p>



<p>この記事では、FIND関数の基本構文からSEARCH関数との違い、LEFT・MID・RIGHTとの組み合わせ実例3パターン、エラー回避まで、実務で使える知識を一通り解説しますよ。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>対象バージョン:</strong> Excel 2016 / 2019 / 2021 / Microsoft 365（Windows・Mac共通）。Excel for the web・Googleスプレッドシートでも同じ構文で使えます。</p></blockquote>




  <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">FIND関数とSEARCH関数の違い：どちらを使うべきか</a></li><li><a href="#toc2" tabindex="0">FIND関数の基本構文と引数</a><ol><li><a href="#toc3" tabindex="0">書式</a></li><li><a href="#toc4" tabindex="0">戻り値は「1から数えた文字位置」</a></li><li><a href="#toc5" tabindex="0">大文字と小文字は別物として扱う</a></li><li><a href="#toc6" tabindex="0">#VALUE!エラーが出る条件</a></li><li><a href="#toc7" tabindex="0">ワイルドカードは使えない</a></li></ol></li><li><a href="#toc8" tabindex="0">FIND関数の基本的な使い方</a><ol><li><a href="#toc9" tabindex="0">特定の文字が何文字目にあるかを調べる</a></li><li><a href="#toc10" tabindex="0">開始位置を指定して途中から検索する</a></li></ol></li><li><a href="#toc11" tabindex="0">FIND + LEFT/MID/RIGHT 組み合わせパターン3選</a><ol><li><a href="#toc12" tabindex="0">パターン①：商品コードのハイフン位置から型番を抽出する</a></li><li><a href="#toc13" tabindex="0">パターン②：メールアドレスの「@」位置でID・ドメインを分離する</a></li><li><a href="#toc14" tabindex="0">パターン③：全角カッコ「（」「）」の両位置からカッコ内を取り出す</a></li></ol></li><li><a href="#toc15" tabindex="0">2つ目の同一文字を探す：開始位置の指定テクニック</a><ol><li><a href="#toc16" tabindex="0">2つ目のハイフン位置を取得する基本形</a></li><li><a href="#toc17" tabindex="0">FIND+LENで可変長文字列に対応する</a></li></ol></li><li><a href="#toc18" tabindex="0">IFERROR + FIND でエラーを回避する</a><ol><li><a href="#toc19" tabindex="0">#VALUE!エラーの発生原因をおさらい</a></li><li><a href="#toc20" tabindex="0">「0返し」と「空文字返し」の使い分け</a></li></ol></li><li><a href="#toc21" tabindex="0">まとめ：FIND関数の活用ポイント</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">FIND関数とSEARCH関数の違い：どちらを使うべきか</span></h2>



<p>FIND関数の説明に入る前に、ほぼ同じ機能を持つ <strong>SEARCH関数</strong> との違いを先に片付けてしまいましょう。 ここを最初に整理しておくと、以降の解説で「なぜFINDを選ぶのか」が腹落ちしますよ。</p>



<p>両者の違いはシンプルで、ポイントは2つだけです。 1つ目は <strong>大文字小文字を区別するか</strong>、2つ目は <strong>ワイルドカードが使えるか</strong> です。</p>



<figure class="wp-block-table"><table><thead><tr><th>観点</th><th>FIND関数</th><th>SEARCH関数</th></tr></thead><tbody><tr><td>大文字・小文字の区別</td><td>区別する（厳密）</td><td>区別しない（柔軟）</td></tr><tr><td>ワイルドカード（<code>?</code> <code>*</code>）</td><td>非対応</td><td>対応</td></tr><tr><td>主な用途</td><td>完全一致・厳密な位置検索</td><td>表記ゆれ対応・あいまい検索</td></tr><tr><td>エラー条件</td><td>見つからない等で <code>#VALUE!</code></td><td>見つからない等で <code>#VALUE!</code></td></tr><tr><td>構文</td><td><code>=FIND(検索文字, 対象, [開始位置])</code></td><td><code>=SEARCH(検索文字, 対象, [開始位置])</code></td></tr></tbody></table></figure>



<p>使い分けは次のように覚えておけばOKです。 「<strong>データが厳密に揃っているならFIND、表記ゆれがあるならSEARCH</strong>」です。 商品コードやメールアドレスはFIND、ユーザーが自由に入力した文章内の検索はSEARCHが向いています。</p>



<p>SEARCH関数を詳しく知りたい方は、<a href="https://mashukabu.com/excel-function-howto-use-search/">SEARCH関数の使い方記事</a> も合わせて読んでみてくださいね。</p>



<h2 class="wp-block-heading"><span id="toc2">FIND関数の基本構文と引数</span></h2>



<h3 class="wp-block-heading"><span id="toc3">書式</span></h3>



<p>FIND関数の構文は次のとおりです。</p>



<pre class="wp-block-code"><code>=FIND(find_text, within_text, [start_num])</code></pre>



<p>日本語で書き直すとこうなります。</p>



<pre class="wp-block-code"><code>=FIND(検索する文字, 対象の文字列, [開始位置])</code></pre>



<p>引数は3つあり、最後の開始位置だけ省略可能です。 それぞれの役割を表で確認しましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th><th>指定例</th></tr></thead><tbody><tr><td>find_text（検索する文字）</td><td>必須</td><td>探したい文字列。1文字でも複数文字でも可</td><td><code>"-"</code>, <code>"@"</code>, <code>"abc"</code></td></tr><tr><td>within_text（対象の文字列）</td><td>必須</td><td>検索対象のセルまたは文字列</td><td><code>A1</code>, <code>"PRD-001-BK"</code></td></tr><tr><td>start_num（開始位置）</td><td>省略可</td><td>検索を始める文字位置。省略時は1</td><td><code>5</code> → 5文字目から検索</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc4">戻り値は「1から数えた文字位置」</span></h3>



<p>FIND関数が返すのは、<strong>検索文字が対象の中で最初にヒットした位置</strong> を1始まりの整数で表した値です。 たとえば「PRD-001-BK」の「-」を検索すると、1つ目のハイフンは4文字目にあるので4が返ります。</p>



<pre class="wp-block-code"><code>=FIND(&quot;-&quot;, &quot;PRD-001-BK&quot;)
→ 結果: 4</code></pre>



<h3 class="wp-block-heading"><span id="toc5">大文字と小文字は別物として扱う</span></h3>



<p>FINDの最大の特徴は <strong>大文字と小文字を厳密に区別する</strong> ことです。 「A」と「a」は別の文字として扱われるので、表記ゆれがあるデータだと意図通りにヒットしません。</p>



<pre class="wp-block-code"><code>=FIND(&quot;excel&quot;, &quot;I love Excel&quot;)
→ 結果: #VALUE!（&quot;excel&quot;（小文字）は見つからない）

=FIND(&quot;Excel&quot;, &quot;I love Excel&quot;)
→ 結果: 8（&quot;Excel&quot; は8文字目にある）</code></pre>



<p>この挙動が「厳密でありがたい」と感じるか「面倒」と感じるかで、FINDとSEARCHの使い分けが決まります。</p>



<h3 class="wp-block-heading"><span id="toc6">#VALUE!エラーが出る条件</span></h3>



<p>FIND関数でエラーが出るのは、主に次の2パターンです。 どちらもあとのIFERRORセクションで回避方法を紹介しますよ。</p>



<ol class="wp-block-list"><li><strong>検索文字が対象に含まれていない</strong>（例: <code>=FIND("z", "abc")</code> → 「z」は「abc」にない）</li><li><strong>start_numが0以下、またはwithin_textの文字数を超えている</strong>（例: <code>=FIND("a", "abc", 10)</code> → 対象は3文字しかない）</li></ol>



<h3 class="wp-block-heading"><span id="toc7">ワイルドカードは使えない</span></h3>



<p>FIND関数では <code>?</code>（任意の1文字）や <code>*</code>（任意の文字列）といったワイルドカードは使えません。 あいまい検索をしたい場合はSEARCH関数を使うか、<a href="https://mashukabu.com/excel-function-howto-use-substitute/">SUBSTITUTE関数</a> で前処理してからFINDに渡す、といった工夫が必要です。</p>



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



<h3 class="wp-block-heading"><span id="toc9">特定の文字が何文字目にあるかを調べる</span></h3>



<p>まずは一番シンプルな使い方からです。 セルA2に「PRD-001-BK」という商品コードが入っているとして、最初のハイフンが何文字目にあるかを調べてみましょう。</p>



<pre class="wp-block-code"><code>=FIND(&quot;-&quot;, A2)
→ 結果: 4</code></pre>



<p>「PRD」の3文字のあとにハイフンが来るので、4が返りますね。</p>



<h3 class="wp-block-heading"><span id="toc10">開始位置を指定して途中から検索する</span></h3>



<p>FIND関数の3つ目の引数 <code>start_num</code> を使うと、検索開始位置をずらせます。 たとえば「PRD-001-BK」の5文字目以降から「-」を探すとこうなります。</p>



<pre class="wp-block-code"><code>=FIND(&quot;-&quot;, A2, 5)
→ 結果: 8</code></pre>



<p>1つ目のハイフン（4文字目）は無視されて、2つ目のハイフン（8文字目）が見つかりましたね。 この「開始位置の指定」は、後述の「2つ目の同一文字を探す」テクニックで大活躍します。</p>



<h2 class="wp-block-heading"><span id="toc11">FIND + LEFT/MID/RIGHT 組み合わせパターン3選</span></h2>



<p>ここからが本記事のメインテーマです。 FIND関数は単独で使うことはほぼなく、LEFT・MID・RIGHTの切り出し位置を自動算出するパーツとして組み合わせるのが定番です。 実務でよく使う3パターンを具体的に見ていきましょう。</p>



<h3 class="wp-block-heading"><span id="toc12">パターン①：商品コードのハイフン位置から型番を抽出する</span></h3>



<p>商品コード「PRD-001-BK」から真ん中の型番「001」だけを取り出したいケースを考えます。 型番の前後はハイフンで挟まれているので、「1つ目のハイフンの次の文字」から「2つ目のハイフンの1つ前」までを切り出せばOKですね。</p>



<p>これを数式にするとこうなります。</p>



<pre class="wp-block-code"><code>=MID(A2, FIND(&quot;-&quot;, A2)+1, FIND(&quot;-&quot;, A2, FIND(&quot;-&quot;, A2)+1)-FIND(&quot;-&quot;, A2)-1)</code></pre>



<p>一見複雑ですが、パーツに分解すれば怖くありません。</p>



<ul class="wp-block-list"><li><code>FIND("-", A2)</code> → 1つ目のハイフン位置（4）</li><li><code>FIND("-", A2, FIND("-", A2)+1)</code> → 2つ目のハイフン位置（8）</li><li>開始位置: <code>FIND("-", A2)+1</code> = 5</li><li>文字数: <code>8 - 4 - 1</code> = 3</li></ul>



<p>結果として「001」が取り出せます。 MID関数の仕様を詳しく知りたい方は <a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数の使い方記事</a> も参考にしてくださいね。</p>



<h3 class="wp-block-heading"><span id="toc13">パターン②：メールアドレスの「@」位置でID・ドメインを分離する</span></h3>



<p>次はメールアドレスを「ユーザーID」と「ドメイン」に分離するパターンです。 「taro@example.com」のように <code>@</code> が1つだけあるフォーマットなので、FINDで <code>@</code> の位置を取れば左右に分解できます。</p>



<p>セルA2に <code>taro@example.com</code> が入っているとして、ユーザーID側を取り出す式はこうです。</p>



<pre class="wp-block-code"><code>=LEFT(A2, FIND(&quot;@&quot;, A2)-1)
→ 結果: taro</code></pre>



<p>「@の位置 &#8211; 1」の文字数だけ左から取り出せば、@ の直前までが切り出せますね。 LEFT関数の詳細は <a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数の使い方記事</a> で解説しています。</p>



<p>続けてドメイン側です。 「全体の長さ &#8211; @の位置」の文字数を右から取ればOKで、可変長のドメインにも対応できます。</p>



<pre class="wp-block-code"><code>=RIGHT(A2, LEN(A2)-FIND(&quot;@&quot;, A2))
→ 結果: example.com</code></pre>



<p><code>LEN(A2)</code> で全体の文字数（16）を取り、そこから <code>@</code> の位置（5）を引いた11文字をRIGHTで切り出しています。 RIGHT関数は <a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT関数の使い方記事</a>、LEN関数は <a href="https://mashukabu.com/excel-function-howto-use-len/">LEN関数の使い方記事</a> に詳しい解説があります。</p>



<h3 class="wp-block-heading"><span id="toc14">パターン③：全角カッコ「（」「）」の両位置からカッコ内を取り出す</span></h3>



<p>3つ目は「商品名（送料込み）」から、カッコ内の「送料込み」だけを抜き出すパターンです。 FIND関数を2回使って「（」と「）」の位置を取得し、MIDで挟まれた部分を切り出します。</p>



<p>セルA2に <code>商品名（送料込み）</code> が入っているとすると、式はこうなります。</p>



<pre class="wp-block-code"><code>=MID(A2, FIND(&quot;（&quot;, A2)+1, FIND(&quot;）&quot;, A2)-FIND(&quot;（&quot;, A2)-1)
→ 結果: 送料込み</code></pre>



<p>ロジックはパターン①と同じで、「（の次の位置」から「）の1つ前までの文字数」を取っているだけです。 全角カッコと半角カッコが混在するデータでは、SUBSTITUTEで統一してから処理すると安定しますよ。</p>



<h2 class="wp-block-heading"><span id="toc15">2つ目の同一文字を探す：開始位置の指定テクニック</span></h2>



<p>商品コード「PRD-001-BK」のように同じ文字が複数含まれるとき、「2つ目のハイフンだけを狙いたい」場面がよくあります。 ここで活躍するのが、FIND関数の3つ目の引数 <code>start_num</code> です。</p>



<h3 class="wp-block-heading"><span id="toc16">2つ目のハイフン位置を取得する基本形</span></h3>



<p>考え方はシンプルで、「1つ目のハイフン位置の次の文字から検索を再開する」というだけです。</p>



<pre class="wp-block-code"><code>=FIND(&quot;-&quot;, A2, FIND(&quot;-&quot;, A2)+1)
→ 結果: 8</code></pre>



<p>内側の <code>FIND("-", A2)</code> で1つ目のハイフン位置（4）を取り、<code>+1</code> した5文字目から再検索します。 そうすると2つ目のハイフン位置（8）が返ります。 この「FINDのネスト」は商品コード解析で頻出するパターンなので、覚えておくと武器になりますよ。</p>



<h3 class="wp-block-heading"><span id="toc17">FIND+LENで可変長文字列に対応する</span></h3>



<p>ハイフン区切りのコードで、各パートの長さが可変になることもあります。 たとえば「PRD-12-BK」「PRD-0001-WH」のように型番の桁数がバラバラなケースです。</p>



<p>末尾の「BK」「WH」を取り出すには「2つ目のハイフンの次から末尾まで」を切り出せばよく、その文字数は <code>LEN - 2つ目のハイフン位置</code> で計算できます。</p>



<pre class="wp-block-code"><code>=RIGHT(A2, LEN(A2)-FIND(&quot;-&quot;, A2, FIND(&quot;-&quot;, A2)+1))</code></pre>



<p>セルA2が「PRD-0001-WH」なら、LENは11、2つ目のハイフン位置は9、差分は2なのでRIGHTで末尾2文字「WH」が取れます。 可変長データにFINDとLENを組み合わせるこの型は、応用範囲がとても広いですよ。</p>



<h2 class="wp-block-heading"><span id="toc18">IFERROR + FIND でエラーを回避する</span></h2>



<p>ここまで紹介した式は「必ず検索文字が含まれている」前提でしたが、実務データにはハイフンなしのコードやメールアドレス不備の行が混ざることがよくあります。 そのままFIND関数を通すと <code>#VALUE!</code> エラーが返り、以降の計算がすべて崩れてしまいます。 これを防ぐのが <a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a> との組み合わせです。</p>



<h3 class="wp-block-heading"><span id="toc19">#VALUE!エラーの発生原因をおさらい</span></h3>



<p>FIND関数でエラーになる代表的な原因は次の2つです。</p>



<ul class="wp-block-list"><li>検索文字がwithin_textに含まれていない（例: ハイフンなしの商品コード）</li><li>start_numが0以下、またはwithin_textの文字数より大きい</li></ul>



<p>どちらも「たまに混ざるイレギュラーなデータ」で発生しがちです。 集計シート全体が <code>#VALUE!</code> で埋め尽くされるのはよくある事故なので、IFERRORでの保険は必ず入れておきたいところです。</p>



<h3 class="wp-block-heading"><span id="toc20">「0返し」と「空文字返し」の使い分け</span></h3>



<p>IFERROR+FINDの書き方には、大きく分けて2パターンあります。</p>



<p><strong>パターン1：0を返す</strong></p>



<pre class="wp-block-code"><code>=IFERROR(FIND(&quot;-&quot;, A2), 0)</code></pre>



<p>エラー時に0を返す書き方です。 返り値を後続のMIDやLEFTに渡す場合や、ヒット数をカウントしたい場合に向いています。 0が返ったセルだけ別処理する、といった分岐にも使えますよ。</p>



<p><strong>パターン2：空文字を返す</strong></p>



<pre class="wp-block-code"><code>=IFERROR(FIND(&quot;-&quot;, A2), &quot;&quot;)</code></pre>



<p>エラー時に空文字を返す書き方です。 一覧表示で「該当なしの行は空欄にしたい」ときに向いています。 ただし空文字は数値ではないので、後続の数式に直接つなぐとかえってエラーになることがあります。注意してください。</p>



<p><strong>使い分けの目安</strong></p>



<ul class="wp-block-list"><li>後続の数式で計算に使う → <strong>0返し</strong>（数値として扱える）</li><li>表示用・目視確認用 → <strong>空文字返し</strong>（0だと紛らわしい場面で有効）</li><li>LEFT/MID/RIGHTに直接つなぐ → IFERRORを <strong>外側に巻く</strong> 書き方が安全</li></ul>



<p>たとえばメールアドレスのID抽出なら、IFERRORを外側に巻く書き方が実用的です。</p>



<pre class="wp-block-code"><code>=IFERROR(LEFT(A2, FIND(&quot;@&quot;, A2)-1), &quot;&quot;)</code></pre>



<p>こう書いておけば、「@が含まれない不正なメールアドレス」の行は空欄になり、集計が止まりません。</p>



<h2 class="wp-block-heading"><span id="toc21">まとめ：FIND関数の活用ポイント</span></h2>



<p>FIND関数の使いどころを最後に整理しますね。</p>



<ul class="wp-block-list"><li><strong>基本</strong>: <code>=FIND(検索文字, 対象, [開始位置])</code> で1始まりの位置を返す。大文字小文字は <strong>区別する</strong>、ワイルドカードは <strong>非対応</strong></li><li><strong>SEARCH関数との使い分け</strong>: 厳密なデータ（コード・メールアドレス）はFIND、表記ゆれやあいまい検索はSEARCH</li><li><strong>LEFT/MID/RIGHTとの組み合わせが本領</strong>: 商品コードの型番抽出・メールアドレス分離・カッコ内抽出の3パターンはテンプレとして覚えると実務で即戦力</li><li><strong>開始位置の指定</strong> は「2つ目の同一文字」を狙うときの必須テクニック。FINDをネストするとシンプルに書ける</li><li><strong>FIND+LEN</strong> の組み合わせで可変長文字列にも対応できる</li><li><strong>IFERRORでの保険</strong> を忘れずに。0返しは数値計算向き、空文字返しは表示向き。LEFT/MID/RIGHTと組み合わせるときはIFERRORを外側に巻くのが安全</li></ul>



<p>FIND関数は単独で眺めるとシンプルですが、LEFT・MID・RIGHT・LEN・IFERROR・SUBSTITUTEと組み合わせることで、実務データをきれいにさばけるようになります。 文字列操作の全体像を俯瞰したい方は、<a href="https://mashukabu.com/excel-string-functions-guide/">Excelの文字列関数まとめ</a> もぜひ読んでみてくださいね。 1つずつ手を動かして試せば、「コードの分解は手作業でやる」状態から必ず卒業できますよ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-find/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>ExcelのLEFT関数の使い方｜文字列の左から指定文字数を取り出す方法</title>
		<link>https://mashukabu.com/excel-function-howto-use-left/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-left/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 04 Apr 2026 04:32:44 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[LEFTB関数]]></category>
		<category><![CDATA[LEFT関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[RIGHT関数]]></category>
		<category><![CDATA[データ整形]]></category>
		<category><![CDATA[文字列操作]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=5782</guid>

					<description><![CDATA[ExcelのLEFT関数で文字列の左端から指定した文字数を取り出す方法を解説。LEFTB関数との違い、FIND・LEN関数との組み合わせ、商品コード・都道府県名の抽出など実務例も紹介します。]]></description>
										<content:encoded><![CDATA[
<p>Excelで「文字列の先頭から何文字かだけ取り出したい」と思ったことはありませんか？ 商品コードの頭2文字でカテゴリを判定したり、郵便番号の上3桁で地域を分類したりと、先頭部分だけ抜き出したい場面は意外と多いですよね。 手作業でやると件数が増えるほどミスも増えて大変です。</p>



<p>そんなときに使えるのが <strong>LEFT関数</strong> です。 左端から指定した文字数を一発で取り出せるので、データ整理がぐっと楽になりますよ。 この記事では、LEFT関数の基本構文からFIND関数との組み合わせまで、実務に使える知識を順を追って解説します。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>対象バージョン:</strong> Excel 2016 / 2019 / 2021 / Microsoft 365（Windows・Mac共通）</p></blockquote>




  <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">LEFT関数とは？文字列の先頭から文字を取り出す関数</a></li><li><a href="#toc2" tabindex="0">LEFT関数の書き方（構文・引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">文字数を省略すると1文字が返る</a></li><li><a href="#toc5" tabindex="0">全角・半角のカウント方法</a></li></ol></li><li><a href="#toc6" tabindex="0">LEFT関数の基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">セル参照で先頭から取り出す</a></li><li><a href="#toc8" tabindex="0">文字数を多めに指定した場合の動作</a></li><li><a href="#toc9" tabindex="0">結果は常に文字列になる</a></li></ol></li><li><a href="#toc10" tabindex="0">LEFT関数の実務活用パターン</a><ol><li><a href="#toc11" tabindex="0">パターン1: 商品コードの頭2文字でカテゴリを判定する</a></li><li><a href="#toc12" tabindex="0">パターン2: 郵便番号の上3桁を取り出す</a></li><li><a href="#toc13" tabindex="0">パターン3: 日付文字列から年だけ取り出す</a></li><li><a href="#toc14" tabindex="0">パターン4: FIND関数と組み合わせて区切り文字の手前を取り出す</a></li><li><a href="#toc15" tabindex="0">パターン5: メールアドレスから@より前のユーザー名を取り出す</a></li><li><a href="#toc16" tabindex="0">パターン6: 都道府県名を住所から抽出する</a></li></ol></li><li><a href="#toc17" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc18" tabindex="0">#VALUE!エラーが出るケース</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">LEFT関数とLEFTB関数の違い</a></li><li><a href="#toc22" tabindex="0">似た関数との比較・使い分け</a></li><li><a href="#toc23" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">LEFT関数とは？文字列の先頭から文字を取り出す関数</span></h2>



<p>ExcelのLEFT関数は、文字列の <strong>左端（先頭）から指定した文字数</strong> を取り出す関数です。 読み方は「レフト」で、英語の「Left（左）」がそのまま由来になっています。</p>



<p>たとえば「東京都渋谷区」から「東京都」だけ取り出す、「AB-001」から「AB」だけ取り出す、といった操作が1つの関数で完了します。</p>



<p>Excelには文字を取り出す関数が3つあります。 まずは全体像を把握しておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>取り出す位置</th><th>引数</th><th>使いどころ</th></tr></thead><tbody><tr><td>LEFT</td><td>先頭（左端）から</td><td>文字列, 文字数</td><td>先頭のコード・郵便番号上3桁など</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT</a></td><td>末尾（右端）から</td><td>文字列, 文字数</td><td>末尾の拡張子・年度下2桁など</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID</a></td><td>任意の位置（途中）から</td><td>文字列, 開始位置, 文字数</td><td>コード中央の分類番号など</td></tr></tbody></table></figure>



<p>LEFT関数は「先頭から何文字」と指定するだけなので、3つの中で一番シンプルです。 文字列操作の入門としてもおすすめですよ。</p>



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



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



<p>LEFT関数の構文は次のとおりです。</p>



<pre class="wp-block-code"><code>=LEFT(文字列, [文字数])</code></pre>



<p>引数は2つで、文字数は省略可能です。 それぞれの役割を表で確認しましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th><th>指定例</th></tr></thead><tbody><tr><td>文字列</td><td>必須</td><td>取り出し元の文字列またはセル参照</td><td>A1, &#8220;ABCDE&#8221;</td></tr><tr><td>文字数</td><td>省略可</td><td>先頭から何文字取り出すか（省略時は1）</td><td>3 → 先頭3文字</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc4">文字数を省略すると1文字が返る</span></h3>



<p>文字数を省略した場合、先頭の <strong>1文字だけ</strong> が返ります。</p>



<pre class="wp-block-code"><code>=LEFT(&quot;Excel&quot;)
→ 結果: &quot;E&quot;</code></pre>



<p>「とりあえず先頭1文字がほしい」ときは、文字数を書かなくてOKです。</p>



<h3 class="wp-block-heading"><span id="toc5">全角・半角のカウント方法</span></h3>



<p>LEFT関数では、全角文字も半角文字も <strong>1文字=1</strong> としてカウントされます。</p>



<pre class="wp-block-code"><code>=LEFT(&quot;エクセル&quot;, 2)
→ 結果: &quot;エク&quot;

=LEFT(&quot;Excel&quot;, 2)
→ 結果: &quot;Ex&quot;</code></pre>



<p>どちらも2文字として扱われます。 バイト数で計算したい場合は後述のLEFTB関数を使いますが、通常の業務ではLEFT関数で問題ありません。</p>



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



<h3 class="wp-block-heading"><span id="toc7">セル参照で先頭から取り出す</span></h3>



<p>実務では直接値よりセル参照を使うのが一般的です。 セルA1に「PRD-001-BK」が入っている場合を見てみましょう。</p>



<pre class="wp-block-code"><code>=LEFT(A1, 3)
→ 結果: &quot;PRD&quot;</code></pre>



<p>先頭から3文字分、つまり「PRD」が取り出されます。 ハイフンやスペースも1文字としてカウントされるので注意してくださいね。</p>



<h3 class="wp-block-heading"><span id="toc8">文字数を多めに指定した場合の動作</span></h3>



<p>「文字列の長さより大きい数を指定したらどうなるの？」と気になる方もいるかもしれません。 結論から言うと、エラーにはなりません。 文字列全体がそのまま返ります。</p>



<pre class="wp-block-code"><code>=LEFT(&quot;Hello&quot;, 100)
→ 結果: &quot;Hello&quot;</code></pre>



<p>はみ出した分は無視されるので、安心して使ってください。</p>



<h3 class="wp-block-heading"><span id="toc9">結果は常に文字列になる</span></h3>



<p>LEFT関数の結果は <strong>常に文字列</strong> です。 数字を取り出しても、そのままでは計算に使えません。</p>



<pre class="wp-block-code"><code>=LEFT(&quot;12345&quot;, 3)
→ 結果: &quot;123&quot;（文字列として返る）</code></pre>



<p>取り出した数字でSUM関数やIF関数の計算をしたいときは、VALUE関数で数値に変換する必要があります。</p>



<pre class="wp-block-code"><code>=VALUE(LEFT(A1, 3))</code></pre>



<p>VALUE関数で囲むだけで、数値として扱えるようになりますよ。</p>



<h2 class="wp-block-heading"><span id="toc10">LEFT関数の実務活用パターン</span></h2>



<p>ここからは、実務でよく使う活用パターンを紹介します。 基本から応用まで段階的に見ていきましょう。</p>



<h3 class="wp-block-heading"><span id="toc11">パターン1: 商品コードの頭2文字でカテゴリを判定する</span></h3>



<p>商品コード「AB-001」「CD-002」のように、先頭2文字がカテゴリを表しているケースです。</p>



<pre class="wp-block-code"><code>=LEFT(A1, 2)
→ 結果: &quot;AB&quot;</code></pre>



<p>取り出した2文字を使って、IF関数やVLOOKUP関数で分類処理につなげられます。 LEFT関数は「他の関数への橋渡し役」としても活躍しますよ。</p>



<h3 class="wp-block-heading"><span id="toc12">パターン2: 郵便番号の上3桁を取り出す</span></h3>



<p>「123-4567」形式の郵便番号から、上3桁（地域コード）を取り出す例です。</p>



<pre class="wp-block-code"><code>=LEFT(A1, 3)
→ 結果: &quot;123&quot;</code></pre>



<p>先頭3文字を取るだけなので、ハイフンの位置を気にする必要はありません。 郵便番号を地域ごとに集計・分類したいときに便利です。</p>



<h3 class="wp-block-heading"><span id="toc13">パターン3: 日付文字列から年だけ取り出す</span></h3>



<p>「2026-04-04」のようなテキスト形式の日付から年だけ取り出す場合です。</p>



<pre class="wp-block-code"><code>=LEFT(A1, 4)
→ 結果: &quot;2026&quot;</code></pre>



<p>年が先頭4文字に入っているので、LEFT関数でスパッと取り出せます。 ただし、セルが日付型（シリアル値）の場合は表示と異なる結果になることがあります。 日付型の場合はTEXT関数で文字列に変換してから使いましょう。</p>



<pre class="wp-block-code"><code>=LEFT(TEXT(A1, &quot;YYYY-MM-DD&quot;), 4)</code></pre>



<h3 class="wp-block-heading"><span id="toc14">パターン4: FIND関数と組み合わせて区切り文字の手前を取り出す</span></h3>



<p>ここからが実務で大活躍するパターンです。 「田中 太郎」からスペースの手前「田中」を取り出す場合を考えましょう。</p>



<p>姓の長さは人によって違うので、文字数を固定できません。 こうした <strong>可変長データ</strong> には<a href="https://mashukabu.com/excel-function-howto-use-mid/">FIND関数</a>（検索文字の位置を返す関数）が頼りになります。</p>



<pre class="wp-block-code"><code>=LEFT(A1, FIND(&quot; &quot;, A1) - 1)</code></pre>



<p>この式を分解すると、次のとおりです。</p>



<ol class="wp-block-list"><li>FIND(&#8221; &#8220;, A1) → スペースの位置を取得（「田中 太郎」なら3）</li><li>&#8211; 1 → スペースの1つ手前まで（3-1=2文字）</li><li>LEFT(A1, 2) → 先頭から2文字「田中」を取り出す</li></ol>



<p>FIND関数が区切り文字の位置を自動で見つけてくれるので、姓が2文字でも3文字でも対応できますよ。</p>



<h3 class="wp-block-heading"><span id="toc15">パターン5: メールアドレスから@より前のユーザー名を取り出す</span></h3>



<p>「tanaka@example.com」から「tanaka」を取り出すケースです。 パターン4と同じ考え方です。</p>



<pre class="wp-block-code"><code>=LEFT(A1, FIND(&quot;@&quot;, A1) - 1)
→ 結果: &quot;tanaka&quot;</code></pre>



<p>FIND(&#8220;@&#8221;, A1) で@の位置（7）を取得し、そこから1を引いた6文字をLEFTで取り出しています。</p>



<p>ただし、@が含まれないデータが混在する場合はFIND関数がエラーを返します。 <a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>（エラー時に別の値を返す関数）で囲んでおくと安心です。</p>



<pre class="wp-block-code"><code>=IFERROR(LEFT(A1, FIND(&quot;@&quot;, A1) - 1), &quot;&quot;)</code></pre>



<p>エラー時は空文字を返すので、他のデータに影響しません。</p>



<h3 class="wp-block-heading"><span id="toc16">パターン6: 都道府県名を住所から抽出する</span></h3>



<p>住所データから都道府県名だけを取り出す場面はとても多いですよね。 ただし、都道府県名は「東京都」が3文字、「神奈川県」が4文字と長さが異なるのが厄介です。</p>



<p>IF関数を使って、4文字の都道府県かどうかで分岐させる方法が定番です。</p>



<pre class="wp-block-code"><code>=IF(MID(A1,4,1)=&quot;県&quot;, LEFT(A1,4), LEFT(A1,3))</code></pre>



<p>この式の考え方はこうです。</p>



<ol class="wp-block-list"><li><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a>で4文字目を確認</li><li>4文字目が「県」なら4文字の県（神奈川県、和歌山県、鹿児島県）</li><li>そうでなければ3文字（東京都、大阪府、北海道、その他の県）</li></ol>



<p>「北海道」は3文字なので3文字パターンで取得できます。 多くの実務データではこの方法で十分対応できますよ。</p>



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



<p>LEFT関数を使っていて「あれ？」となるケースをまとめました。</p>



<h3 class="wp-block-heading"><span id="toc18">#VALUE!エラーが出るケース</span></h3>



<p>#VALUE! エラーの原因はほぼ1つです。</p>



<ul class="wp-block-list"><li><strong>文字数にマイナスの値を指定している</strong></li></ul>



<pre class="wp-block-code"><code>=LEFT(A1, -1)
→ #VALUE! エラー</code></pre>



<p>FIND関数と組み合わせたときに起こりやすいパターンです。 検索文字が見つからないとFIND関数が #VALUE! を返し、LEFT関数にも波及します。</p>



<pre class="wp-block-code"><code>=IFERROR(LEFT(A1, FIND(&quot;-&quot;, A1) - 1), A1)</code></pre>



<p><a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>で囲んでおけば、区切り文字がないデータでもエラーになりません。</p>



<h3 class="wp-block-heading"><span id="toc19">数値セルで意図しない結果になるケース</span></h3>



<p>LEFT関数は文字列を扱う関数です。 数値セルに使うと、書式に関係なくセルの実際の値から取り出されます。</p>



<p>たとえば、日付セルに <code>2026/4/4</code> と表示されていても、内部的にはシリアル値（46114のような数値）です。 LEFT関数はこのシリアル値の先頭から取り出してしまいます。</p>



<pre class="wp-block-code"><code>=LEFT(A1, 4)  ← 日付セル
→ 結果: &quot;4611&quot;（表示値と異なる!）</code></pre>



<p>対策は、TEXT関数で表示形式を文字列に変換してからLEFTを適用することです。</p>



<pre class="wp-block-code"><code>=LEFT(TEXT(A1, &quot;YYYY/MM/DD&quot;), 4)
→ 結果: &quot;2026&quot;</code></pre>



<h3 class="wp-block-heading"><span id="toc20">空文字が返るケース</span></h3>



<p>LEFT関数が空文字（&#8221;&#8221;）を返すのは次のケースです。</p>



<ul class="wp-block-list"><li><strong>文字数に0を指定した場合</strong></li><li><strong>参照セルが空の場合</strong></li></ul>



<p>どちらもエラーにはなりませんが、意図した結果かどうか確認しておきましょう。</p>



<h2 class="wp-block-heading"><span id="toc21">LEFT関数とLEFTB関数の違い</span></h2>



<p>LEFT関数とよく比較されるのがLEFTB関数です。 両者の違いは <strong>文字の数え方</strong> にあります。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>LEFT関数</th><th>LEFTB関数</th></tr></thead><tbody><tr><td>カウント基準</td><td>文字数（1文字=1）</td><td>バイト数（全角=2、半角=1）</td></tr><tr><td>「Excel」の長さ</td><td>5</td><td>5（すべて半角）</td></tr><tr><td>「エクセル」の長さ</td><td>4</td><td>8（すべて全角）</td></tr><tr><td>主な用途</td><td>一般的な文字抽出</td><td>固定バイト長データの処理</td></tr></tbody></table></figure>



<p>LEFTB関数の構文はLEFT関数と同じです。</p>



<pre class="wp-block-code"><code>=LEFTB(文字列, [バイト数])</code></pre>



<p>具体例で見てみましょう。 「エクセル関数」から取り出す場合に結果が変わります。</p>



<pre class="wp-block-code"><code>=LEFT(&quot;エクセル関数&quot;, 3)
→ 結果: &quot;エクセ&quot;（3文字）

=LEFTB(&quot;エクセル関数&quot;, 3)
→ 結果: &quot;エ&quot;（3バイト = 全角1文字 + 半端な1バイトは切り捨て）</code></pre>



<p>LEFTB関数は、全角文字を2バイト、半角文字を1バイトとして計算します。 3バイト指定だと全角は1文字（2バイト）＋余り1バイトとなり、半端な文字は切り捨てられます。</p>



<p>通常の業務では <strong>LEFT関数を使えば問題ありません</strong>。 LEFTB関数が必要になるのは、レガシーシステムから出力された固定バイト長データ（COBOL系や銀行データなど）を扱うような限られた場面だけです。</p>



<h2 class="wp-block-heading"><span id="toc22">似た関数との比較・使い分け</span></h2>



<p>LEFT関数と併用する機会が多い関数を整理しました。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>役割</th><th>LEFTとの関係</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT</a></td><td>末尾から文字を取り出す</td><td>LEFTの逆方向版</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID</a></td><td>任意の位置から文字を取り出す</td><td>中央の取り出しに使う</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-len/">LEN</a></td><td>文字数を数える</td><td>LEFTの文字数指定に活用</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-trim/">TRIM</a></td><td>余分なスペースを除去する</td><td>LEFT適用前のデータ前処理に</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-substitute/">SUBSTITUTE</a></td><td>文字列を置換する</td><td>区切り文字の変換と組み合わせ</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR</a></td><td>エラー時に別の値を返す</td><td>FIND連携時のエラー防止に</td></tr></tbody></table></figure>



<p>どの関数を使うか迷ったときは、次の判断フレームで選んでみてください。</p>



<ul class="wp-block-list"><li><strong>先頭から数えたほうが早い</strong> → LEFT関数</li><li><strong>末尾から数えたほうが早い</strong> → <a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT関数</a></li><li><strong>真ん中あたりにある</strong> → <a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a></li><li><strong>区切り文字の前後で分けたい</strong> → LEFT + FIND または MID + FIND</li></ul>



<p>文字列操作の関数を体系的に学びたい方は、<a href="https://mashukabu.com/excel-string-functions-guide/">Excelの文字列関数まとめ</a>もあわせてチェックしてみてくださいね。</p>



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



<p>この記事では、ExcelのLEFT関数の使い方を基本から実務活用まで解説しました。 最後にポイントを振り返りましょう。</p>



<ul class="wp-block-list"><li>LEFT関数は <code>=LEFT(文字列, 文字数)</code> で先頭から文字を取り出す</li><li>文字数を省略すると <strong>1文字だけ</strong> 返る</li><li>文字数を多めに指定してもエラーにならず、文字列全体が返る</li><li>FIND関数と組み合わせれば、可変長の区切り文字にも対応できる</li><li>LEFTB関数はバイト単位で数える関数で、通常業務ではLEFTで十分</li><li>結果は文字列になるので、数値として使うならVALUE関数で変換する</li></ul>



<p>LEFT関数は文字列操作の基本中の基本です。 まずは「先頭から何文字取り出す」というシンプルな使い方から試してみてください。 FIND関数との組み合わせに慣れれば、データ整理の幅がぐっと広がりますよ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-left/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>ExcelのRIGHT関数の使い方｜文字列の右から指定文字数を取り出す方法</title>
		<link>https://mashukabu.com/excel-function-howto-use-right/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-right/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 04 Apr 2026 04:32:39 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[LEFT関数]]></category>
		<category><![CDATA[LEN関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[RIGHTB関数]]></category>
		<category><![CDATA[RIGHT関数]]></category>
		<category><![CDATA[データ整形]]></category>
		<category><![CDATA[文字列操作]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=5780</guid>

					<description><![CDATA[ExcelのRIGHT関数で文字列の右端から指定した文字数を取り出す方法を解説。RIGHTB関数との違い、LEN・FIND関数との組み合わせ、電話番号末尾や拡張子の抽出など実務例も紹介します。]]></description>
										<content:encoded><![CDATA[
<p>Excelで「文字列の末尾から何文字かだけ取り出したい」と思ったことはありませんか？ 電話番号の下4桁を取り出したり、ファイル名から拡張子だけ抽出したりと、末尾の文字を抜き出す場面は想像以上に多いですよね。 手作業で1件ずつコピーしていたら、件数が増えるほど時間もミスも増えてしまいます。</p>



<p>そんなときに使えるのが <strong>RIGHT関数</strong> です。 文字列の右端から指定した文字数をサッと取り出せるので、データ整理の効率が一気に上がりますよ。 この記事では、RIGHT関数の基本構文からLEN・FIND関数との組み合わせまで、実務に使える知識を順を追って解説します。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>対象バージョン:</strong> Excel 2016 / 2019 / 2021 / Microsoft 365（Windows・Mac共通）</p></blockquote>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-3" checked><label class="toc-title" for="toc-checkbox-3">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">RIGHT関数とは？文字列の末尾から文字を取り出す関数</a></li><li><a href="#toc2" tabindex="0">RIGHT関数の書き方（構文・引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">文字数を省略すると1文字が返る</a></li><li><a href="#toc5" tabindex="0">全角・半角のカウント方法</a></li></ol></li><li><a href="#toc6" tabindex="0">RIGHT関数の基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">セル参照で末尾から取り出す</a></li><li><a href="#toc8" tabindex="0">文字数を多めに指定した場合の動作</a></li><li><a href="#toc9" tabindex="0">結果は常に文字列になる</a></li></ol></li><li><a href="#toc10" tabindex="0">RIGHT関数の実務活用パターン</a><ol><li><a href="#toc11" tabindex="0">パターン1: 電話番号の末尾4桁を取り出す</a></li><li><a href="#toc12" tabindex="0">パターン2: ファイル名から拡張子を取り出す</a></li><li><a href="#toc13" tabindex="0">パターン3: 年度コードの下2桁を取り出す</a></li><li><a href="#toc14" tabindex="0">パターン4: FIND関数と組み合わせて区切り文字の後ろを取り出す</a></li><li><a href="#toc15" tabindex="0">パターン5: メールアドレスからドメインを取り出す</a></li><li><a href="#toc16" tabindex="0">パターン6: 住所から市区町村以降を取り出す</a></li></ol></li><li><a href="#toc17" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc18" tabindex="0">#VALUE!エラーが出るケース</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">RIGHT関数とRIGHTB関数の違い</a></li><li><a href="#toc22" tabindex="0">似た関数との比較・使い分け</a></li><li><a href="#toc23" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">RIGHT関数とは？文字列の末尾から文字を取り出す関数</span></h2>



<p>ExcelのRIGHT関数は、文字列の <strong>右端（末尾）から指定した文字数</strong> を取り出す関数です。 読み方は「ライト」で、英語の「Right（右）」がそのまま由来になっています。</p>



<p>たとえば「03-1234-5678」から末尾4桁の「5678」を取り出す、「report.xlsx」から「xlsx」を取り出す、といった操作が1つの関数で完了します。</p>



<p>Excelには文字を取り出す関数が3つあります。 まずは全体像を押さえておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>取り出す位置</th><th>引数</th><th>使いどころ</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT</a></td><td>先頭（左端）から</td><td>文字列, 文字数</td><td>先頭のコード・郵便番号上3桁など</td></tr><tr><td>RIGHT</td><td>末尾（右端）から</td><td>文字列, 文字数</td><td>末尾の拡張子・電話番号下4桁など</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID</a></td><td>任意の位置（途中）から</td><td>文字列, 開始位置, 文字数</td><td>コード中央の分類番号など</td></tr></tbody></table></figure>



<p>RIGHT関数は<a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>の逆方向版です。 「末尾から何文字」と指定するだけなので、使い方もシンプルですよ。</p>



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



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



<p>RIGHT関数の構文は次のとおりです。</p>



<pre class="wp-block-code"><code>=RIGHT(文字列, [文字数])</code></pre>



<p>引数は2つで、文字数は省略可能です。 それぞれの役割を表で確認しましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th><th>指定例</th></tr></thead><tbody><tr><td>文字列</td><td>必須</td><td>取り出し元の文字列またはセル参照</td><td>A1, &#8220;ABCDE&#8221;</td></tr><tr><td>文字数</td><td>省略可</td><td>末尾から何文字取り出すか（省略時は1）</td><td>4 → 末尾4文字</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc4">文字数を省略すると1文字が返る</span></h3>



<p>文字数を省略した場合、末尾の <strong>1文字だけ</strong> が返ります。</p>



<pre class="wp-block-code"><code>=RIGHT(&quot;Excel&quot;)
→ 結果: &quot;l&quot;</code></pre>



<p>「とりあえず末尾1文字がほしい」ときは、文字数を書かなくてOKです。</p>



<h3 class="wp-block-heading"><span id="toc5">全角・半角のカウント方法</span></h3>



<p>RIGHT関数では、全角文字も半角文字も <strong>1文字=1</strong> としてカウントされます。</p>



<pre class="wp-block-code"><code>=RIGHT(&quot;エクセル&quot;, 2)
→ 結果: &quot;セル&quot;

=RIGHT(&quot;Excel&quot;, 2)
→ 結果: &quot;el&quot;</code></pre>



<p>どちらも2文字として扱われます。 バイト数で計算したい場合は後述のRIGHTB関数を使いますが、通常の業務ではRIGHT関数で問題ありません。</p>



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



<h3 class="wp-block-heading"><span id="toc7">セル参照で末尾から取り出す</span></h3>



<p>実務では直接値よりセル参照を使うのが一般的です。 セルA1に「PRD-001-BK」が入っている場合を見てみましょう。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, 2)
→ 結果: &quot;BK&quot;</code></pre>



<p>末尾から2文字分、つまりカラーコード「BK」が取り出されます。 <a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>が先頭から取り出すのに対し、RIGHT関数は末尾から取り出すのがポイントです。</p>



<h3 class="wp-block-heading"><span id="toc8">文字数を多めに指定した場合の動作</span></h3>



<p>「文字列の長さより大きい数を指定したらどうなるの？」と気になる方もいるかもしれません。 結論から言うと、エラーにはなりません。 文字列全体がそのまま返ります。</p>



<pre class="wp-block-code"><code>=RIGHT(&quot;Hello&quot;, 100)
→ 結果: &quot;Hello&quot;</code></pre>



<p>はみ出した分は無視されるので、安心して使ってください。</p>



<h3 class="wp-block-heading"><span id="toc9">結果は常に文字列になる</span></h3>



<p>RIGHT関数の結果は <strong>常に文字列</strong> です。 数字を取り出しても、そのままでは計算に使えません。</p>



<pre class="wp-block-code"><code>=RIGHT(&quot;12345&quot;, 3)
→ 結果: &quot;345&quot;（文字列として返る）</code></pre>



<p>取り出した数字でSUM関数やIF関数の計算をしたいときは、<a href="https://mashukabu.com/excel-function-howto-use-value/">VALUE関数</a>（文字列を数値に変換する関数）で変換する必要があります。</p>



<pre class="wp-block-code"><code>=VALUE(RIGHT(A1, 3))</code></pre>



<p>VALUE関数で囲むだけで、数値として扱えるようになりますよ。</p>



<h2 class="wp-block-heading"><span id="toc10">RIGHT関数の実務活用パターン</span></h2>



<p>ここからは、実務でよく使う活用パターンを紹介します。 基本から応用まで段階的に見ていきましょう。</p>



<h3 class="wp-block-heading"><span id="toc11">パターン1: 電話番号の末尾4桁を取り出す</span></h3>



<p>「03-1234-5678」のような電話番号から、末尾4桁だけ取り出すケースです。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, 4)
→ 結果: &quot;5678&quot;</code></pre>



<p>末尾4文字を取るだけなので、電話番号の桁数やハイフンの位置に影響されません。 顧客データの照合や、末尾番号でのグループ分けに使えますよ。</p>



<h3 class="wp-block-heading"><span id="toc12">パターン2: ファイル名から拡張子を取り出す</span></h3>



<p>「report.xlsx」や「photo.png」のようなファイル名から拡張子を取り出す場面です。 ただし、拡張子の文字数は3文字だったり4文字だったりと一定ではありませんよね。</p>



<p>固定長なら簡単ですが、可変長の場合はFIND関数と<a href="https://mashukabu.com/excel-function-howto-use-len/">LEN関数</a>（文字数を数える関数）を組み合わせます。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, LEN(A1) - FIND(&quot;.&quot;, A1))</code></pre>



<p>この式を分解すると、次のとおりです。</p>



<ol class="wp-block-list"><li>FIND(&#8220;.&#8221;, A1) → ドットの位置を取得（「report.xlsx」なら7）</li><li><a href="https://mashukabu.com/excel-function-howto-use-len/">LEN</a>(A1) → 文字列全体の長さ（11）</li><li>LEN(A1) &#8211; FIND(&#8220;.&#8221;, A1) → ドットより後ろの文字数（11 &#8211; 7 = 4）</li><li>RIGHT(A1, 4) → 末尾4文字「xlsx」を取り出す</li></ol>



<p>RIGHT + LEN + FIND のこの組み合わせは、<strong>区切り文字より後ろを取り出す定番パターン</strong> です。 ぜひ覚えておいてくださいね。</p>



<h3 class="wp-block-heading"><span id="toc13">パターン3: 年度コードの下2桁を取り出す</span></h3>



<p>「FY2026」のような年度コードから、下2桁「26」だけ取り出す例です。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, 2)
→ 結果: &quot;26&quot;</code></pre>



<p>帳票の表示スペースが限られているときや、年度の下2桁で集計キーを作りたいときに便利です。</p>



<h3 class="wp-block-heading"><span id="toc14">パターン4: FIND関数と組み合わせて区切り文字の後ろを取り出す</span></h3>



<p>パターン2で紹介した考え方をさらに発展させましょう。 「田中 太郎」からスペースの後ろ「太郎」を取り出す場合です。</p>



<p><a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>ではスペースの手前を取り出しましたが、RIGHT関数ではスペースの後ろを取り出します。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, LEN(A1) - FIND(&quot; &quot;, A1))</code></pre>



<p>この式の流れです。</p>



<ol class="wp-block-list"><li>FIND(&#8221; &#8220;, A1) → スペースの位置（「田中 太郎」なら3）</li><li><a href="https://mashukabu.com/excel-function-howto-use-len/">LEN</a>(A1) → 全体の文字数（5）</li><li>LEN(A1) &#8211; FIND(&#8221; &#8220;, A1) → スペースより後ろの文字数（5 &#8211; 3 = 2）</li><li>RIGHT(A1, 2) → 末尾2文字「太郎」を取り出す</li></ol>



<p>LEFT関数が「区切り文字の手前」を取るのに対し、RIGHT関数は「区切り文字の後ろ」を取る。 この対の関係を覚えておくと、文字列の分割がスムーズにできますよ。</p>



<h3 class="wp-block-heading"><span id="toc15">パターン5: メールアドレスからドメインを取り出す</span></h3>



<p>「tanaka@example.com」から「example.com」を取り出すケースです。 パターン4と同じ考え方です。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, LEN(A1) - FIND(&quot;@&quot;, A1))
→ 結果: &quot;example.com&quot;</code></pre>



<p>FIND(&#8220;@&#8221;, A1) で@の位置を取得し、全体の長さから引いた文字数をRIGHTで取り出しています。</p>



<p>ただし、@が含まれないデータが混在する場合はFIND関数がエラーを返します。 <a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>（エラー時に別の値を返す関数）で囲んでおくと安心です。</p>



<pre class="wp-block-code"><code>=IFERROR(RIGHT(A1, LEN(A1) - FIND(&quot;@&quot;, A1)), &quot;&quot;)</code></pre>



<p>エラー時は空文字を返すので、他のデータに影響しません。 LEFT関数でユーザー名を取り出す方法は<a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数の実務活用パターン</a>で紹介しています。</p>



<h3 class="wp-block-heading"><span id="toc16">パターン6: 住所から市区町村以降を取り出す</span></h3>



<p>都道府県名を除いた住所部分を取り出す場面です。 <a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数の記事</a>では都道府県名の取り出し方を紹介しましたが、RIGHT関数では逆に「都道府県名を除いた部分」を取り出します。</p>



<p>都道府県名は3文字か4文字なので、IF関数と<a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a>で分岐させます。</p>



<pre class="wp-block-code"><code>=IF(MID(A1,4,1)=&quot;県&quot;, RIGHT(A1, LEN(A1)-4), RIGHT(A1, LEN(A1)-3))</code></pre>



<p>この式の考え方はこうです。</p>



<ol class="wp-block-list"><li><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a>で4文字目を確認</li><li>4文字目が「県」なら4文字の県（神奈川県、和歌山県、鹿児島県）→ 4文字分を除く</li><li>そうでなければ3文字（東京都、大阪府、北海道、その他の県）→ 3文字分を除く</li></ol>



<p>LEFT関数で都道府県を取り出し、RIGHT関数で残りの市区町村を取り出す。 セットで使うときれいにデータを分割できますよ。</p>



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



<p>RIGHT関数を使っていて「あれ？」となるケースをまとめました。</p>



<h3 class="wp-block-heading"><span id="toc18">#VALUE!エラーが出るケース</span></h3>



<p>#VALUE! エラーの原因はほぼ1つです。</p>



<ul class="wp-block-list"><li><strong>文字数にマイナスの値を指定している</strong></li></ul>



<pre class="wp-block-code"><code>=RIGHT(A1, -1)
→ #VALUE! エラー</code></pre>



<p>FIND関数やLEN関数と組み合わせたときに起こりやすいパターンです。 区切り文字が見つからないとFIND関数が #VALUE! を返し、RIGHT関数にも波及します。</p>



<pre class="wp-block-code"><code>=IFERROR(RIGHT(A1, LEN(A1) - FIND(&quot;-&quot;, A1)), A1)</code></pre>



<p><a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>で囲んでおけば、区切り文字がないデータでもエラーになりません。</p>



<h3 class="wp-block-heading"><span id="toc19">数値セルで意図しない結果になるケース</span></h3>



<p>RIGHT関数は文字列を扱う関数です。 数値セルに使うと、書式に関係なくセルの実際の値から取り出されます。</p>



<p>たとえば、日付セルに <code>2026/4/4</code> と表示されていても、内部的にはシリアル値（46114のような数値）です。 RIGHT関数はこのシリアル値の末尾から取り出してしまいます。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, 2)  ← 日付セル
→ 結果: &quot;14&quot;（表示値と異なる!）</code></pre>



<p>対策は、TEXT関数で表示形式を文字列に変換してからRIGHTを適用することです。</p>



<pre class="wp-block-code"><code>=RIGHT(TEXT(A1, &quot;YYYY/MM/DD&quot;), 2)
→ 結果: &quot;04&quot;</code></pre>



<h3 class="wp-block-heading"><span id="toc20">空文字が返るケース</span></h3>



<p>RIGHT関数が空文字（&#8221;&#8221;）を返すのは次のケースです。</p>



<ul class="wp-block-list"><li><strong>文字数に0を指定した場合</strong></li><li><strong>参照セルが空の場合</strong></li></ul>



<p>どちらもエラーにはなりませんが、意図した結果かどうか確認しておきましょう。</p>



<h2 class="wp-block-heading"><span id="toc21">RIGHT関数とRIGHTB関数の違い</span></h2>



<p>RIGHT関数とよく比較されるのがRIGHTB関数です。 両者の違いは <strong>文字の数え方</strong> にあります。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>RIGHT関数</th><th>RIGHTB関数</th></tr></thead><tbody><tr><td>カウント基準</td><td>文字数（1文字=1）</td><td>バイト数（全角=2、半角=1）</td></tr><tr><td>「Excel」の長さ</td><td>5</td><td>5（すべて半角）</td></tr><tr><td>「エクセル」の長さ</td><td>4</td><td>8（すべて全角）</td></tr><tr><td>主な用途</td><td>一般的な文字抽出</td><td>固定バイト長データの処理</td></tr></tbody></table></figure>



<p>RIGHTB関数の構文はRIGHT関数と同じです。</p>



<pre class="wp-block-code"><code>=RIGHTB(文字列, [バイト数])</code></pre>



<p>具体例で見てみましょう。 「エクセル関数」から取り出す場合に結果が変わります。</p>



<pre class="wp-block-code"><code>=RIGHT(&quot;エクセル関数&quot;, 3)
→ 結果: &quot;関数&quot;ではなく &quot;ル関数&quot;（末尾3文字）

=RIGHTB(&quot;エクセル関数&quot;, 3)
→ 結果: &quot;数&quot;（末尾3バイト = 全角1文字 + 半端な1バイトは切り捨て）</code></pre>



<p>RIGHTB関数は、全角文字を2バイト、半角文字を1バイトとして計算します。 3バイト指定だと全角は1文字（2バイト）＋余り1バイトとなり、半端な文字は切り捨てられます。</p>



<p>通常の業務では <strong>RIGHT関数を使えば問題ありません</strong>。 RIGHTB関数が必要になるのは、レガシーシステムから出力された固定バイト長データ（COBOL系や銀行データなど）を扱うような限られた場面だけです。</p>



<h2 class="wp-block-heading"><span id="toc22">似た関数との比較・使い分け</span></h2>



<p>RIGHT関数と併用する機会が多い関数を整理しました。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>役割</th><th>RIGHTとの関係</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT</a></td><td>先頭から文字を取り出す</td><td>RIGHTの逆方向版</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID</a></td><td>任意の位置から文字を取り出す</td><td>中央の取り出しに使う</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-len/">LEN</a></td><td>文字数を数える</td><td>RIGHT+FINDで必須の相棒</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-trim/">TRIM</a></td><td>余分なスペースを除去する</td><td>RIGHT適用前のデータ前処理に</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-substitute/">SUBSTITUTE</a></td><td>文字列を置換する</td><td>区切り文字の変換と組み合わせ</td></tr><tr><td><a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR</a></td><td>エラー時に別の値を返す</td><td>FIND連携時のエラー防止に</td></tr></tbody></table></figure>



<p>どの関数を使うか迷ったときは、次の判断フレームで選んでみてください。</p>



<ul class="wp-block-list"><li><strong>先頭から数えたほうが早い</strong> → <a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a></li><li><strong>末尾から数えたほうが早い</strong> → RIGHT関数</li><li><strong>真ん中あたりにある</strong> → <a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a></li><li><strong>区切り文字の前を取りたい</strong> → LEFT + FIND</li><li><strong>区切り文字の後ろを取りたい</strong> → RIGHT + LEN + FIND</li></ul>



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



<p>この記事では、ExcelのRIGHT関数の使い方を基本から実務活用まで解説しました。 最後にポイントを振り返りましょう。</p>



<ul class="wp-block-list"><li>RIGHT関数は <code>=RIGHT(文字列, 文字数)</code> で末尾から文字を取り出す</li><li>文字数を省略すると <strong>1文字だけ</strong> 返る</li><li>文字数を多めに指定してもエラーにならず、文字列全体が返る</li><li>LEN関数・FIND関数と組み合わせれば、区切り文字の後ろを柔軟に取り出せる</li><li>RIGHTB関数はバイト単位で数える関数で、通常業務ではRIGHTで十分</li><li>結果は文字列になるので、数値として使うなら<a href="https://mashukabu.com/excel-function-howto-use-value/">VALUE関数</a>で変換する</li></ul>



<p>RIGHT関数は<a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>とセットで覚えるのがおすすめです。 「先頭からはLEFT、末尾からはRIGHT」と対で覚えておけば、文字列の分割がスムーズになりますよ。 まずは電話番号の末尾4桁やファイルの拡張子取り出しなど、身近なデータで試してみてくださいね。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-right/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>ExcelのSEARCH関数の使い方｜大文字小文字を区別しない文字列検索</title>
		<link>https://mashukabu.com/excel-function-howto-use-search/</link>
					<comments>https://mashukabu.com/excel-function-howto-use-search/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 04 Apr 2026 04:32:35 +0000</pubDate>
				<category><![CDATA[Excel関数]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[IFERROR関数]]></category>
		<category><![CDATA[LEFT関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[RIGHT関数]]></category>
		<category><![CDATA[SEARCHB関数]]></category>
		<category><![CDATA[SEARCH関数]]></category>
		<category><![CDATA[ワイルドカード]]></category>
		<category><![CDATA[文字列操作]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=5778</guid>

					<description><![CDATA[ExcelのSEARCH関数で大文字小文字を区別せずに文字列の位置を検索する方法を解説。FIND関数との違い、ワイルドカードの活用、SEARCHB関数との比較、MID・LEFTとの組み合わせなど実務例も紹介します。]]></description>
										<content:encoded><![CDATA[
<p>Excelで「この文字列の中に特定の文字が何文字目にあるか調べたい」と思ったことはありませんか？ しかもデータに大文字・小文字が混在していて、「Excel」も「EXCEL」も同じように見つけたい場面は意外と多いですよね。 手作業で目視チェックするのは、データ量が増えるほど現実的ではありません。</p>



<p>そんなときに使えるのが <strong>SEARCH関数</strong> です。 大文字・小文字を区別しないで文字列の位置を返してくれるので、表記ゆれがあるデータでも安心して検索できますよ。 この記事では、SEARCH関数の基本構文からワイルドカード活用、LEFT・MID関数との組み合わせまで、実務に使える知識を順を追って解説します。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>対象バージョン:</strong> Excel 2016 / 2019 / 2021 / Microsoft 365（Windows・Mac共通）</p></blockquote>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-4" checked><label class="toc-title" for="toc-checkbox-4">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">SEARCH関数とは？大文字小文字を区別しない文字列検索</a></li><li><a href="#toc2" tabindex="0">SEARCH関数の書き方（構文・引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">戻り値は「先頭からの文字位置」</a></li><li><a href="#toc5" tabindex="0">見つからない場合は#VALUE!エラー</a></li></ol></li><li><a href="#toc6" tabindex="0">SEARCH関数の基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">特定の文字が何番目にあるか調べる</a></li><li><a href="#toc8" tabindex="0">大文字小文字を区別しない検索</a></li><li><a href="#toc9" tabindex="0">開始位置を指定して2つ目の文字を探す</a></li></ol></li><li><a href="#toc10" tabindex="0">SEARCH関数の実務活用パターン</a><ol><li><a href="#toc11" tabindex="0">パターン1: LEFT関数と組み合わせて区切り文字の手前を取り出す</a></li><li><a href="#toc12" tabindex="0">パターン2: MID関数と組み合わせて区切り文字の後ろを取り出す</a></li><li><a href="#toc13" tabindex="0">パターン3: RIGHT関数と組み合わせてファイル拡張子を取り出す</a></li><li><a href="#toc14" tabindex="0">パターン4: ワイルドカードであいまい検索する</a></li><li><a href="#toc15" tabindex="0">パターン5: IF関数と組み合わせてカテゴリ分類する</a></li></ol></li><li><a href="#toc16" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc17" tabindex="0">#VALUE!エラーが出るケース</a></li><li><a href="#toc18" tabindex="0">ワイルドカード文字そのものを検索したいとき</a></li><li><a href="#toc19" tabindex="0">意図しない位置がマッチするケース</a></li></ol></li><li><a href="#toc20" tabindex="0">SEARCH関数とSEARCHB関数の違い</a></li><li><a href="#toc21" tabindex="0">SEARCH関数とFIND関数の使い分け</a></li><li><a href="#toc22" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">SEARCH関数とは？大文字小文字を区別しない文字列検索</span></h2>



<p>ExcelのSEARCH関数は、文字列の中から <strong>指定した文字が何文字目にあるか</strong> を返す関数です。 読み方は「サーチ」で、英語の「Search（検索する）」が由来になっています。</p>



<p>最大の特徴は <strong>大文字と小文字を区別しない</strong> ことです。 たとえば「Excel」というセルに対してSEARCH(&#8220;excel&#8221;, A1)と書いても、ちゃんと1が返ります。</p>



<p>もう1つの特徴は <strong>ワイルドカードが使える</strong> ことです。 <code>?</code>（任意の1文字）や <code>*</code>（任意の文字列）を検索文字に指定でき、あいまい検索ができます。</p>



<p>SEARCH関数とよく比較されるFIND関数との違いを、まず一覧で確認しておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>SEARCH関数</th><th>FIND関数</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>同じ</td><td>同じ</td></tr></tbody></table></figure>



<p>「大文字小文字を気にせず探したい」「パターンであいまい検索したい」ならSEARCH関数、「完全に一致する文字だけ探したい」ならFIND関数、と覚えておけばOKです。</p>



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



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



<p>SEARCH関数の構文は次のとおりです。</p>



<pre class="wp-block-code"><code>=SEARCH(検索文字列, 対象, [開始位置])</code></pre>



<p>引数は3つで、開始位置は省略可能です。 それぞれの役割を表で確認しましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th><th>指定例</th></tr></thead><tbody><tr><td>検索文字列</td><td>必須</td><td>探したい文字列（ワイルドカード使用可）</td><td>&#8220;abc&#8221;, &#8220;?-*&#8221;</td></tr><tr><td>対象</td><td>必須</td><td>検索対象のセルまたは文字列</td><td>A1, &#8220;Hello World&#8221;</td></tr><tr><td>開始位置</td><td>省略可</td><td>検索を開始する位置（省略時は1）</td><td>5 → 5文字目から検索</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc4">戻り値は「先頭からの文字位置」</span></h3>



<p>SEARCH関数が返すのは、<strong>検索文字列が見つかった先頭位置</strong>（1から始まる番号）です。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;World&quot;, &quot;Hello World&quot;)
→ 結果: 7</code></pre>



<p>「Hello World」の中で「World」は7文字目から始まっているので、7が返ります。</p>



<h3 class="wp-block-heading"><span id="toc5">見つからない場合は#VALUE!エラー</span></h3>



<p>検索文字列が対象の中に存在しないと、<code>#VALUE!</code> エラーになります。 エラーを回避するには<a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>で囲むのが定番です。</p>



<pre class="wp-block-code"><code>=IFERROR(SEARCH(&quot;xyz&quot;, A1), 0)</code></pre>



<p>見つからないときに0を返す設定にしておけば、後続の処理でエラーが波及しません。</p>



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



<h3 class="wp-block-heading"><span id="toc7">特定の文字が何番目にあるか調べる</span></h3>



<p>セルA1に「PRD-001-BK」が入っている場合、最初のハイフンの位置を調べてみましょう。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;-&quot;, A1)
→ 結果: 4</code></pre>



<p>ハイフンは4文字目にあるので、4が返ります。</p>



<h3 class="wp-block-heading"><span id="toc8">大文字小文字を区別しない検索</span></h3>



<p>SEARCH関数の真骨頂です。 セルA1に「Microsoft Excel」が入っている場合を見てみましょう。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;excel&quot;, A1)
→ 結果: 11</code></pre>



<p>検索文字列を小文字の「excel」にしていますが、対象の「Excel」（先頭大文字）もちゃんとマッチします。 FIND関数では同じ式が <code>#VALUE!</code> エラーになるので、ここがSEARCH関数の強みですね。</p>



<h3 class="wp-block-heading"><span id="toc9">開始位置を指定して2つ目の文字を探す</span></h3>



<p>セルA1に「PRD-001-BK」が入っているとき、2つ目のハイフンの位置を取得する方法です。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;-&quot;, A1, SEARCH(&quot;-&quot;, A1) + 1)
→ 結果: 8</code></pre>



<p>この式を分解すると、次のとおりです。</p>



<ol class="wp-block-list"><li>内側のSEARCH(&#8220;-&#8220;, A1) → 最初のハイフンの位置（4）を取得</li><li>+1 → その次の文字（5文字目）から検索を再開</li><li>外側のSEARCH → 2つ目のハイフンの位置（8）を取得</li></ol>



<p>開始位置をうまく活用すれば、同じ文字が複数ある場合でもピンポイントで探せますよ。</p>



<h2 class="wp-block-heading"><span id="toc10">SEARCH関数の実務活用パターン</span></h2>



<p>ここからは、実務でよく使う活用パターンを紹介します。 SEARCH関数は単体よりも <strong>他の関数と組み合わせて使う</strong> ことが多い関数です。</p>



<h3 class="wp-block-heading"><span id="toc11">パターン1: LEFT関数と組み合わせて区切り文字の手前を取り出す</span></h3>



<p>「田中 太郎」からスペースの手前「田中」を取り出す定番パターンです。</p>



<pre class="wp-block-code"><code>=LEFT(A1, SEARCH(&quot; &quot;, A1) - 1)
→ 結果: &quot;田中&quot;</code></pre>



<p>この式の流れはこうです。</p>



<ol class="wp-block-list"><li>SEARCH(&#8221; &#8220;, A1) → スペースの位置（3）を取得</li><li>&#8211; 1 → スペースの1つ手前まで（2文字）</li><li><a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>で先頭から2文字を取り出す</li></ol>



<p>全角スペースにも対応するので、氏名データの分割に重宝しますよ。</p>



<h3 class="wp-block-heading"><span id="toc12">パターン2: MID関数と組み合わせて区切り文字の後ろを取り出す</span></h3>



<p>今度は「田中 太郎」から名前「太郎」を取り出すパターンです。</p>



<pre class="wp-block-code"><code>=MID(A1, SEARCH(&quot; &quot;, A1) + 1, LEN(A1))
→ 結果: &quot;太郎&quot;</code></pre>



<ol class="wp-block-list"><li>SEARCH(&#8221; &#8220;, A1) → スペースの位置（3）</li><li>+1 → スペースの次の文字（4文字目）から開始</li><li><a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a>で4文字目から末尾まで取り出す（文字数を大きめに指定すれば末尾まで取れます）</li></ol>



<p>LEFT＋SEARCHで「前半」、MID＋SEARCHで「後半」と覚えておくと便利です。</p>



<h3 class="wp-block-heading"><span id="toc13">パターン3: RIGHT関数と組み合わせてファイル拡張子を取り出す</span></h3>



<p>「report_2026.xlsx」からピリオド以降の拡張子を取り出す例です。</p>



<pre class="wp-block-code"><code>=RIGHT(A1, LEN(A1) - SEARCH(&quot;.&quot;, A1))
→ 結果: &quot;xlsx&quot;</code></pre>



<ol class="wp-block-list"><li>SEARCH(&#8220;.&#8221;, A1) → ピリオドの位置（12）</li><li>LEN(A1) &#8211; 12 → ピリオドより後ろの文字数（4）</li><li><a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT関数</a>で末尾から4文字を取り出す</li></ol>



<p>ファイル名の一覧から拡張子だけ抜き出してフィルタリングしたいときに使えます。</p>



<h3 class="wp-block-heading"><span id="toc14">パターン4: ワイルドカードであいまい検索する</span></h3>



<p>SEARCH関数ならではの機能がワイルドカード検索です。 <code>?</code> は任意の1文字、<code>*</code> は0文字以上の任意の文字列にマッチします。</p>



<p><strong>例1: パターンマッチで商品コードを検索する</strong></p>



<p>「X」で始まり「Z」で終わる3文字のコードがあるかチェックする場合です。</p>



<pre class="wp-block-code"><code>=IFERROR(SEARCH(&quot;X?Z&quot;, A1), 0)</code></pre>



<p>A1が「AX9Z-100」なら、「X9Z」にマッチして2が返ります。 A1が「ABC-100」なら見つからず0が返ります。</p>



<p><strong>例2: 特定の文字を含むかどうかを判定する</strong></p>



<p>セルの中に「Excel」という単語が含まれるかどうかを TRUE / FALSE で判定する方法です。</p>



<pre class="wp-block-code"><code>=ISNUMBER(SEARCH(&quot;excel&quot;, A1))
→ 結果: TRUE または FALSE</code></pre>



<p>SEARCH関数が数値を返せばISNUMBER関数がTRUEになり、<code>#VALUE!</code> エラーならFALSEになります。 大文字小文字を無視して含有チェックできるので、データの振り分けに便利ですよ。</p>



<h3 class="wp-block-heading"><span id="toc15">パターン5: IF関数と組み合わせてカテゴリ分類する</span></h3>



<p>商品名にキーワードが含まれるかで分類するパターンです。</p>



<pre class="wp-block-code"><code>=IF(ISNUMBER(SEARCH(&quot;premium&quot;, A1)), &quot;上位モデル&quot;, &quot;通常モデル&quot;)</code></pre>



<p>「Premium」「PREMIUM」「premium」のどの表記でもヒットするので、表記ゆれがあるデータでも正確に分類できます。</p>



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



<p>SEARCH関数で「あれ？」となるケースをまとめました。</p>



<h3 class="wp-block-heading"><span id="toc17">#VALUE!エラーが出るケース</span></h3>



<p>#VALUE! エラーの原因は主に2つです。</p>



<ul class="wp-block-list"><li><strong>検索文字列が対象に含まれていない</strong></li><li><strong>開始位置が対象の文字数を超えている</strong></li></ul>



<pre class="wp-block-code"><code>=SEARCH(&quot;xyz&quot;, &quot;Hello&quot;)
→ #VALUE! エラー（見つからない）

=SEARCH(&quot;H&quot;, &quot;Hello&quot;, 100)
→ #VALUE! エラー（開始位置が範囲外）</code></pre>



<p>どちらも<a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>で対処するのが定番です。</p>



<pre class="wp-block-code"><code>=IFERROR(SEARCH(&quot;xyz&quot;, A1), &quot;見つかりません&quot;)</code></pre>



<h3 class="wp-block-heading"><span id="toc18">ワイルドカード文字そのものを検索したいとき</span></h3>



<p><code>?</code> や <code>*</code> をワイルドカードではなく、文字として検索したい場合は <strong>チルダ（~）</strong> を前に付けます。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;~?&quot;, A1)
→ 「?」という文字そのものの位置を返す

=SEARCH(&quot;~*&quot;, A1)
→ 「*」という文字そのものの位置を返す</code></pre>



<p>チルダ自体を検索したい場合は <code>~~</code> と2つ重ねます。 ワイルドカードが予期せずマッチしてしまうときは、この方法を思い出してくださいね。</p>



<h3 class="wp-block-heading"><span id="toc19">意図しない位置がマッチするケース</span></h3>



<p>SEARCH関数は <strong>最初に見つかった位置</strong> を返します。 2番目以降の位置が欲しい場合は、開始位置の引数を活用しましょう（基本的な使い方のセクションで解説しました）。</p>



<h2 class="wp-block-heading"><span id="toc20">SEARCH関数とSEARCHB関数の違い</span></h2>



<p>SEARCH関数にはバイト単位で動作する <strong>SEARCHB関数</strong> があります。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>SEARCH関数</th><th>SEARCHB関数</th></tr></thead><tbody><tr><td>カウント基準</td><td>文字数（1文字=1）</td><td>バイト数（全角=2、半角=1）</td></tr><tr><td>「エクセル」の中の「セル」</td><td>3</td><td>5</td></tr><tr><td>主な用途</td><td>一般的な文字位置検索</td><td>固定バイト長データの処理</td></tr></tbody></table></figure>



<p>SEARCHB関数の構文はSEARCH関数と同じです。</p>



<pre class="wp-block-code"><code>=SEARCHB(検索文字列, 対象, [開始位置])</code></pre>



<p>具体例を見てみましょう。 「エクセル関数」の中から「関数」を探す場合です。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;関数&quot;, &quot;エクセル関数&quot;)
→ 結果: 5（5文字目）

=SEARCHB(&quot;関数&quot;, &quot;エクセル関数&quot;)
→ 結果: 9（9バイト目）</code></pre>



<p>SEARCHB関数は全角文字を2バイトとしてカウントするので、位置がずれます。</p>



<p>通常の業務では <strong>SEARCH関数を使えば問題ありません</strong>。 SEARCHB関数が必要になるのは、レガシーシステムから出力された固定バイト長データを扱う場合など、限られた場面だけです。</p>



<h2 class="wp-block-heading"><span id="toc21">SEARCH関数とFIND関数の使い分け</span></h2>



<p>SEARCH関数とFIND関数は構文が同じなので、どちらを使うか迷いがちです。 判断基準をもう少し掘り下げましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>使うべき場面</th><th>選ぶ関数</th><th>理由</th></tr></thead><tbody><tr><td>大文字小文字の区別が不要</td><td>SEARCH</td><td>表記ゆれを無視できる</td></tr><tr><td>ワイルドカードで柔軟に検索したい</td><td>SEARCH</td><td>?, * が使える</td></tr><tr><td>大文字小文字を厳密に区別したい</td><td>FIND</td><td>「abc」と「ABC」を別扱いにできる</td></tr><tr><td>ワイルドカード文字を文字として扱いたい</td><td>FIND</td><td>チルダ不要でシンプル</td></tr></tbody></table></figure>



<p><strong>実務でのおすすめ</strong>: 迷ったらまずSEARCH関数を使ってみてください。 大文字小文字を区別しないほうが使い勝手がよい場面がほとんどです。 「厳密に区別する必要がある」と分かったときだけFIND関数に切り替えれば十分ですよ。</p>



<p>SEARCH関数とFIND関数はどちらも、<a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT関数</a>・<a href="https://mashukabu.com/excel-function-howto-use-mid/">MID関数</a>・<a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT関数</a>と組み合わせるパターンで使います。 文字列操作のレパートリーを増やしたい方は、あわせてチェックしてみてくださいね。</p>



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



<p>この記事では、ExcelのSEARCH関数の使い方を基本から実務活用まで解説しました。 最後にポイントを振り返りましょう。</p>



<ul class="wp-block-list"><li>SEARCH関数は <code>=SEARCH(検索文字列, 対象, [開始位置])</code> で文字列の位置を返す</li><li><strong>大文字・小文字を区別しない</strong> のが最大の特徴</li><li><strong>ワイルドカード（?, *）</strong> が使え、あいまい検索ができる</li><li>見つからない場合は <code>#VALUE!</code> エラーになるので、<a href="https://mashukabu.com/excel-function-howto-use-iferror/">IFERROR関数</a>で囲むのが定番</li><li><a href="https://mashukabu.com/excel-function-howto-use-left/">LEFT</a>・<a href="https://mashukabu.com/excel-function-howto-use-mid/">MID</a>・<a href="https://mashukabu.com/excel-function-howto-use-right/">RIGHT</a>関数と組み合わせて文字列の抽出に活用できる</li><li>FIND関数との違いは「大文字小文字の区別」と「ワイルドカード対応」の2点</li><li>SEARCHB関数はバイト単位版で、通常業務ではSEARCHで十分</li></ul>



<p>SEARCH関数は文字列操作の中でも使用頻度が高い関数です。 まずは「特定の文字が何番目にあるか」を調べるシンプルな使い方から始めてみてください。 LEFT・MID関数と組み合わせるテクニックに慣れれば、データ整理の幅がぐっと広がりますよ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-function-howto-use-search/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのREGEXEXTRACT関数の使い方｜正規表現で文字列を抽出</title>
		<link>https://mashukabu.com/spreadsheet-regexextract-function/</link>
					<comments>https://mashukabu.com/spreadsheet-regexextract-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 21 Mar 2026 11:31:11 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[REGEXEXTRACT関数]]></category>
		<category><![CDATA[REGEXMATCH関数]]></category>
		<category><![CDATA[REGEXREPLACE関数]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[正規表現]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4779</guid>

					<description><![CDATA[スプレッドシートのREGEXEXTRACT関数は、正規表現で文字列から必要な部分だけを抽出する関数です。メールアドレスからドメイン抽出、注文番号の取り出し、電話番号の分解など実務パターンや、MID+FINDとの比較、REGEXMATCH・REGEXREPLACEとの使い分けまで解説します。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートで「住所から都道府県だけ取り出したい」「メールアドレスの@以降を抜き出したい」と思ったことはありませんか？ <a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>と<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>を組み合わせれば文字の位置指定で抽出できます。でも、文字数がバラバラなデータには対応しきれないのが現実です。</p>



<p>REGEXEXTRACT関数を使えば、<strong>正規表現のパターンに一致する部分だけ</strong>をピンポイントで抽出できます。この記事ではREGEXEXTRACT関数の基本から実務パターンまで丁寧に解説しますね。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-5" checked><label class="toc-title" for="toc-checkbox-5">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">REGEXEXTRACT関数とは？正規表現で文字列を抽出する関数</a><ol><li><a href="#toc2" tabindex="0">「正規表現」って何？</a></li></ol></li><li><a href="#toc3" tabindex="0">REGEXEXTRACT関数の書き方（構文と引数）</a><ol><li><a href="#toc4" tabindex="0">基本構文</a></li><li><a href="#toc5" tabindex="0">キャプチャグループ（括弧）の使い方</a></li></ol></li><li><a href="#toc6" tabindex="0">REGEXEXTRACT関数の基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">数字だけを抽出する</a></li><li><a href="#toc8" tabindex="0">特定のパターンを抽出する</a></li><li><a href="#toc9" tabindex="0">複数のキャプチャグループで分割抽出する</a></li><li><a href="#toc10" tabindex="0">大文字・小文字を区別せずに抽出する</a></li></ol></li><li><a href="#toc11" tabindex="0">実務で使えるパターン集</a><ol><li><a href="#toc12" tabindex="0">メールアドレスからドメインを抽出する</a></li><li><a href="#toc13" tabindex="0">URLからドメイン名を抽出する</a></li><li><a href="#toc14" tabindex="0">住所から都道府県を抽出する</a></li><li><a href="#toc15" tabindex="0">電話番号からエリアコードを抽出する</a></li><li><a href="#toc16" tabindex="0">IFERROR関数と組み合わせてエラーを回避する</a></li><li><a href="#toc17" tabindex="0">ARRAYFORMULA関数と組み合わせて一括抽出する</a></li></ol></li><li><a href="#toc18" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc19" tabindex="0">数値セルで#VALUE!エラーになるケース</a></li><li><a href="#toc20" tabindex="0">パターン不一致で#N/Aエラーになるケース</a></li></ol></li><li><a href="#toc21" tabindex="0">MID+FIND関数との比較</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">REGEXMATCH・REGEXREPLACEとの使い分け</a><ol><li><a href="#toc26" tabindex="0">具体例で比較</a></li></ol></li><li><a href="#toc27" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">REGEXEXTRACT関数とは？正規表現で文字列を抽出する関数</span></h2>



<p>REGEXEXTRACT関数は、セルの文字列から<strong>正規表現パターンに一致する部分を抽出</strong>して返す関数です。読み方は「レジェックスエクストラクト」。「Regex（正規表現）」+「Extract（抽出）」が語源です。</p>



<p>たとえば「tanaka@example.com」から <code>@(.+)</code> のパターンで抽出すると「example.com」が返ります。@以降のドメイン部分だけを取り出せるわけです。</p>



<p>REGEXEXTRACT関数は<strong>Googleスプレッドシート独自の関数</strong>で、Excelには存在しません。Excelで同じことをするにはVBAが必要です。スプレッドシートなら関数だけで正規表現抽出ができるのが大きな強みですよ。</p>



<h3 class="wp-block-heading"><span id="toc2">「正規表現」って何？</span></h3>



<p>正規表現とは、文字列のパターンを記号で表すルールです。たとえば <code>[0-9]+</code> は「1文字以上の数字」を意味します。最初はとっつきにくく感じるかもしれません。でも、よく使うパターンは決まっています。この記事で紹介するパターンをコピーして使えばOKです。正規表現の記号一覧は<a href="https://mashukabu.com/spreadsheet-regexmatch-function/">REGEXMATCH関数の記事</a>でまとめていますので、そちらも参考にしてください。</p>



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



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



<pre class="wp-block-code"><code>=REGEXEXTRACT(テキスト, 正規表現)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th></tr></thead><tbody><tr><td>テキスト</td><td>必須</td><td>抽出元の文字列またはセル参照</td></tr><tr><td>正規表現</td><td>必須</td><td>抽出したいパターンの正規表現</td></tr></tbody></table></figure>



<p>戻り値は<strong>パターンに一致した文字列</strong>です。一致する部分がなければ#N/Aエラーになります。</p>



<h3 class="wp-block-heading"><span id="toc5">キャプチャグループ（括弧）の使い方</span></h3>



<p>REGEXEXTRACT関数の正規表現に<strong>括弧 <code>()</code></strong> を使うと、括弧内に一致した部分だけを返します。これを「キャプチャグループ」と呼びます。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(&quot;tanaka@example.com&quot;, &quot;@(.+)&quot;)
  → &quot;example.com&quot;（@の後ろだけを抽出）

=REGEXEXTRACT(&quot;tanaka@example.com&quot;, &quot;.+@(.+)&quot;)
  → &quot;example.com&quot;（同じ結果）

=REGEXEXTRACT(&quot;tanaka@example.com&quot;, &quot;(.+)@&quot;)
  → &quot;tanaka&quot;（@の前だけを抽出）</code></pre>



<p>括弧なしの場合はパターン全体に一致した文字列を返します。括弧ありの場合は括弧内の部分だけを返します。この違いがポイントですよ。</p>



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



<h3 class="wp-block-heading"><span id="toc7">数字だけを抽出する</span></h3>



<p>セルA2に「商品コード: ABC-123」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;[0-9]+&quot;)   → &quot;123&quot;（数字部分を抽出）
=REGEXEXTRACT(A2, &quot;[A-Z]+&quot;)   → &quot;ABC&quot;（英大文字部分を抽出）</code></pre>



<p><code>[0-9]+</code> は「1文字以上の数字」を意味します。最初に一致した部分が返ります。</p>



<h3 class="wp-block-heading"><span id="toc8">特定のパターンを抽出する</span></h3>



<p>セルA2に「受付番号: ORD-2024-0456」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;ORD-d{4}-d{4}&quot;)
  → &quot;ORD-2024-0456&quot;（注文番号パターンを抽出）</code></pre>



<p><code>d{4}</code> は「数字がちょうど4桁」を意味します。パターン全体に一致する文字列がそのまま返ります。</p>



<h3 class="wp-block-heading"><span id="toc9">複数のキャプチャグループで分割抽出する</span></h3>



<p>括弧を複数使うと、それぞれのグループが<strong>別々のセルに展開</strong>されます。</p>



<p>セルA2に「山田太郎 03-1234-5678」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;(.+)s(d{2,4}-d{1,4}-d{3,4})&quot;)
  → &quot;山田太郎&quot; と &quot;03-1234-5678&quot; が隣り合う2つのセルに展開</code></pre>



<p>名前と電話番号を一度に分割できるのが便利ですね。複数グループの結果は横方向のセルに出力されます。</p>



<h3 class="wp-block-heading"><span id="toc10">大文字・小文字を区別せずに抽出する</span></h3>



<p>REGEXEXTRACT関数はデフォルトで<strong>大文字と小文字を区別</strong>します。区別せずに抽出したいときは <code>(?i)</code> を先頭に付けます。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(&quot;Hello World&quot;, &quot;(?i)hello&quot;)
  → &quot;Hello&quot;（大文字小文字を無視してマッチ・抽出）</code></pre>



<h2 class="wp-block-heading"><span id="toc11">実務で使えるパターン集</span></h2>



<h3 class="wp-block-heading"><span id="toc12">メールアドレスからドメインを抽出する</span></h3>



<p>顧客リストのメールアドレスからドメイン部分だけを取り出します。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;@(.+)&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th><th>説明</th></tr></thead><tbody><tr><td>tanaka@example.com</td><td>example.com</td><td>@以降を抽出</td></tr><tr><td>sato@company.co.jp</td><td>company.co.jp</td><td>@以降を抽出</td></tr><tr><td>info@test.org</td><td>test.org</td><td>@以降を抽出</td></tr></tbody></table></figure>



<p>ドメイン別に顧客を集計したいときに便利です。<a href="https://mashukabu.com/spreadsheet-countif-function/">COUNTIF関数</a>と組み合わせれば、ドメイン別の件数集計もできます。</p>



<h3 class="wp-block-heading"><span id="toc13">URLからドメイン名を抽出する</span></h3>



<p>Webサイトの一覧からドメイン名だけを取り出します。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;https?://([^/]+)&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th></tr></thead><tbody><tr><td>https://www.example.com/page</td><td>www.example.com</td></tr><tr><td>http://blog.test.jp/article/123</td><td>blog.test.jp</td></tr></tbody></table></figure>



<p><code>https?://</code> は「httpまたはhttps」を意味します。<code>([^/]+)</code> は「スラッシュ以外の文字が1文字以上」です。</p>



<h3 class="wp-block-heading"><span id="toc14">住所から都道府県を抽出する</span></h3>



<p>住所データから都道府県名だけを取り出します。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;^(.{2,3}[都道府県])&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th></tr></thead><tbody><tr><td>東京都渋谷区神南1-2-3</td><td>東京都</td></tr><tr><td>神奈川県横浜市西区</td><td>神奈川県</td></tr><tr><td>大阪府大阪市北区</td><td>大阪府</td></tr><tr><td>北海道札幌市中央区</td><td>北海道</td></tr></tbody></table></figure>



<p><code>.{2,3}</code> は「任意の文字が2〜3文字」を意味します。「東京（2文字）」から「神奈川（3文字）」まで対応できます。</p>



<h3 class="wp-block-heading"><span id="toc15">電話番号からエリアコードを抽出する</span></h3>



<p>電話番号の先頭部分（エリアコード）だけを取り出します。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;^(0d{1,4})&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th></tr></thead><tbody><tr><td>03-1234-5678</td><td>03</td></tr><tr><td>090-1234-5678</td><td>090</td></tr><tr><td>0120-123-456</td><td>0120</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc16">IFERROR関数と組み合わせてエラーを回避する</span></h3>



<p>REGEXEXTRACT関数はパターンに一致しないと#N/Aエラーを返します。<a href="https://mashukabu.com/spreadsheet-iferror-function/">IFERROR関数</a>で囲めばエラーを回避できます。</p>



<pre class="wp-block-code"><code>=IFERROR(REGEXEXTRACT(A2, &quot;@(.+)&quot;), &quot;ドメインなし&quot;)</code></pre>



<p>パターンに一致しないセルには「ドメインなし」と表示されます。一覧表で使うときは必ずIFERRORで囲むのがおすすめですよ。</p>



<h3 class="wp-block-heading"><span id="toc17">ARRAYFORMULA関数と組み合わせて一括抽出する</span></h3>



<p><a href="https://mashukabu.com/spreadsheet-arrayformula-function/">ARRAYFORMULA関数</a>と組み合わせれば、複数行を一括で処理できます。</p>



<pre class="wp-block-code"><code>=ARRAYFORMULA(IFERROR(REGEXEXTRACT(A2:A100, &quot;@(.+)&quot;), &quot;&quot;))</code></pre>



<p>この数式をB2セルに1つ入れるだけで、A2からA100までのメールアドレスからドメインを一括抽出できます。</p>



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



<figure class="wp-block-table"><table><thead><tr><th>エラー</th><th>原因</th><th>対処法</th></tr></thead><tbody><tr><td>#N/A</td><td>パターンに一致する部分がない</td><td>IFERRORで囲む。正規表現の見直しも確認</td></tr><tr><td>#VALUE!</td><td>テキストが数値</td><td><code>=REGEXEXTRACT(TEXT(A2,"0"), "パターン")</code> で文字列に変換</td></tr><tr><td>#VALUE!</td><td>テキストが空セル</td><td><code>=IF(A2="", "", REGEXEXTRACT(A2, "パターン"))</code> で空チェック</td></tr><tr><td>#REF!</td><td>正規表現の構文エラー</td><td>括弧の閉じ忘れ・エスケープ漏れを確認</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc19">数値セルで#VALUE!エラーになるケース</span></h3>



<p>REGEXEXTRACT関数の第1引数は<strong>文字列</strong>が必要です。セルに数値が入っている場合は#VALUE!エラーです。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;d+&quot;)           → A2が数値だと #VALUE!
=REGEXEXTRACT(TEXT(A2, &quot;0&quot;), &quot;d+&quot;) → TEXT関数で文字列に変換すればOK</code></pre>



<p>数値から一部を抽出したい場合は、<a href="https://mashukabu.com/spreadsheet-text-function/">TEXT関数</a>で文字列に変換してから渡しましょう。</p>



<h3 class="wp-block-heading"><span id="toc20">パターン不一致で#N/Aエラーになるケース</span></h3>



<p><a href="https://mashukabu.com/spreadsheet-regexmatch-function/">REGEXMATCH関数</a>はパターン不一致でFALSEを返します。一方、REGEXEXTRACT関数は<strong>#N/Aエラー</strong>を返します。</p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(&quot;abc&quot;, &quot;d+&quot;)  → #N/A（数字が含まれない）</code></pre>



<p>一覧表で使うときは <code>=IFERROR(REGEXEXTRACT(A2, "パターン"), "")</code> のようにIFERRORで囲むのが定番です。</p>



<h2 class="wp-block-heading"><span id="toc21">MID+FIND関数との比較</span></h2>



<p>文字列の抽出は<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>と<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>の組み合わせでもできます。REGEXEXTRACTとの違いを比較しましょう。</p>



<h3 class="wp-block-heading"><span id="toc22">同じ処理を両方で書いてみる</span></h3>



<p>メールアドレス「tanaka@example.com」から@以降を抽出する場合です。</p>



<p><strong>MID+FIND関数の場合:</strong></p>



<pre class="wp-block-code"><code>=MID(A2, FIND(&quot;@&quot;, A2)+1, LEN(A2)-FIND(&quot;@&quot;, A2))</code></pre>



<p><strong>REGEXEXTRACT関数の場合:</strong></p>



<pre class="wp-block-code"><code>=REGEXEXTRACT(A2, &quot;@(.+)&quot;)</code></pre>



<p>REGEXEXTRACT関数のほうがシンプルですね。MID+FINDは「@の位置を探す→その後ろから末尾までを取る」と2段階の計算が必要です。</p>



<h3 class="wp-block-heading"><span id="toc23">比較表</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>比較項目</th><th>REGEXEXTRACT</th><th>MID + FIND</th></tr></thead><tbody><tr><td>数式の長さ</td><td>短い</td><td>長い（3関数の組み合わせ）</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>複数のFINDが必要</td></tr><tr><td>Excel互換</td><td>なし（Sheets独自）</td><td>あり</td></tr><tr><td>学習コスト</td><td>正規表現の知識が必要</td><td>低い</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc24">どちらを使うべき？</span></h3>



<ul class="wp-block-list"><li><strong>固定位置から切り出す</strong>（左から3文字、5文字目から8文字）→ <a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>・<a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a>・<a href="https://mashukabu.com/spreadsheet-right-function/">RIGHT関数</a>で十分</li><li><strong>パターンで抽出する</strong>（メールのドメイン、URLのパス）→ <strong>REGEXEXTRACT関数</strong>一択</li><li><strong>Excelとの互換性が必要</strong> → MID + FINDを使う</li></ul>



<p>データの形式がバラバラなときほど、REGEXEXTRACT関数の威力を発揮します。</p>



<h2 class="wp-block-heading"><span id="toc25">REGEXMATCH・REGEXREPLACEとの使い分け</span></h2>



<p>スプレッドシートには正規表現を使う関数が3つあります。目的で使い分けましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>目的</th><th>戻り値</th><th>使用例</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/spreadsheet-regexmatch-function/">REGEXMATCH</a></td><td>パターンに<strong>一致するか判定</strong></td><td>TRUE / FALSE</td><td>入力チェック、条件分岐</td></tr><tr><td>REGEXEXTRACT</td><td>パターンに一致する部分を<strong>抽出</strong></td><td>一致した文字列</td><td>ドメイン抽出、番号取り出し</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-regexreplace-function/">REGEXREPLACE</a></td><td>パターンに一致する部分を<strong>置換</strong></td><td>置換後の文字列</td><td>ハイフン除去、書式統一</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc26">具体例で比較</span></h3>



<p>セルA2に「注文番号: ORD-2024-0123」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;ORD-d{4}-d{4}&quot;)
  → TRUE（注文番号パターンに一致するか判定）

=REGEXEXTRACT(A2, &quot;ORD-d{4}-d{4}&quot;)
  → &quot;ORD-2024-0123&quot;（注文番号部分を抽出）

=REGEXREPLACE(A2, &quot;ORD-&quot;, &quot;&quot;)
  → &quot;注文番号: 2024-0123&quot;（「ORD-」を除去）</code></pre>



<p><strong>判定</strong>は<a href="https://mashukabu.com/spreadsheet-regexmatch-function/">REGEXMATCH</a>、<strong>抽出</strong>はREGEXEXTRACT、<strong>置換</strong>はREGEXREPLACEと覚えておきましょう。</p>



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



<p>REGEXEXTRACT関数は、正規表現でパターンに一致する部分を抽出できるスプレッドシート独自の関数です。</p>



<ul class="wp-block-list"><li><strong>基本</strong>: <code>=REGEXEXTRACT(テキスト, 正規表現)</code> で一致部分を返す</li><li><strong>キャプチャグループ</strong>: 括弧 <code>()</code> で囲んだ部分だけを抽出できる</li><li><strong>実務活用</strong>: ドメイン抽出・都道府県抽出・番号分解に最適</li><li><strong>エラー対策</strong>: パターン不一致は#N/Aエラー。IFERRORで囲むのが定番</li><li><strong>使い分け</strong>: 判定はREGEXMATCH、抽出はREGEXEXTRACT、置換はREGEXREPLACE</li></ul>



<p>MID+FINDでは書ききれないパターン抽出が必要なとき、ぜひ活用してみてください。正規表現の基本は<a href="https://mashukabu.com/spreadsheet-regexmatch-function/">REGEXMATCH関数の記事</a>でまとめています。そちらも合わせてチェックしてみてくださいね。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-regexextract-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのREGEXMATCH関数の使い方｜正規表現でパターン判定</title>
		<link>https://mashukabu.com/spreadsheet-regexmatch-function/</link>
					<comments>https://mashukabu.com/spreadsheet-regexmatch-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Sat, 21 Mar 2026 11:31:06 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[REGEXEXTRACT関数]]></category>
		<category><![CDATA[REGEXMATCH関数]]></category>
		<category><![CDATA[REGEXREPLACE関数]]></category>
		<category><![CDATA[SEARCH関数]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[正規表現]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4777</guid>

					<description><![CDATA[スプレッドシートのREGEXMATCH関数は、正規表現でセルの文字列がパターンに一致するかをTRUE/FALSEで返す関数です。メールアドレス・電話番号の判定パターンや、REGEXEXTRACT・REGEXREPLACEとの使い分け、SEARCH/FINDとの違いまで解説します。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートでデータの入力チェックをしたいことはありませんか？「メールアドレスの形式になっているか」「電話番号が正しいパターンか」を確認したい場面は多いですよね。<a href="https://mashukabu.com/spreadsheet-search-function/">SEARCH関数</a>や<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>では単純な文字検索しかできません。複雑なパターンには対応しきれないのが現実です。</p>



<p>REGEXMATCH関数を使えば、<strong>正規表現</strong>で文字列のパターンを判定できます。この記事ではREGEXMATCH関数の基本から実務パターンまで丁寧に解説します。REGEXEXTRACT・REGEXREPLACEとの使い分けもカバーしますね。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-6" checked><label class="toc-title" for="toc-checkbox-6">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">REGEXMATCH関数とは？正規表現でパターン判定する関数</a><ol><li><a href="#toc2" tabindex="0">「正規表現」って何？</a></li></ol></li><li><a href="#toc3" tabindex="0">REGEXMATCH関数の書き方（構文と引数）</a><ol><li><a href="#toc4" tabindex="0">基本構文</a></li><li><a href="#toc5" tabindex="0">正規表現の基本記号</a></li></ol></li><li><a href="#toc6" tabindex="0">基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">特定の文字列が含まれるかを判定する</a></li><li><a href="#toc8" tabindex="0">数字が含まれるかを判定する</a></li><li><a href="#toc9" tabindex="0">大文字・小文字を区別せずに判定する</a></li></ol></li><li><a href="#toc10" tabindex="0">実務で使えるパターン集</a><ol><li><a href="#toc11" tabindex="0">メールアドレスの形式チェック</a></li><li><a href="#toc12" tabindex="0">電話番号の形式チェック</a></li><li><a href="#toc13" tabindex="0">郵便番号の形式チェック</a></li><li><a href="#toc14" tabindex="0">IF関数と組み合わせてラベルを付ける</a></li></ol></li><li><a href="#toc15" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc16" tabindex="0">数値セルで#VALUE!エラーになるケース</a></li><li><a href="#toc17" tabindex="0">正規表現の特殊文字をエスケープし忘れるケース</a></li></ol></li><li><a href="#toc18" tabindex="0">REGEXEXTRACT・REGEXREPLACEとの使い分け</a><ol><li><a href="#toc19" tabindex="0">具体例で比較</a></li></ol></li><li><a href="#toc20" tabindex="0">SEARCH・FIND関数との違い</a><ol><li><a href="#toc21" tabindex="0">どれを使うべき？</a></li></ol></li><li><a href="#toc22" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">REGEXMATCH関数とは？正規表現でパターン判定する関数</span></h2>



<p>REGEXMATCH関数は、セルの文字列が<strong>指定した正規表現パターンに一致するか</strong>をTRUE/FALSEで返す関数です。読み方は「レジェックスマッチ」。「Regex（正規表現）」+「Match（一致）」が語源です。</p>



<p>たとえば「tanaka@example.com」というセルに対して、メールアドレスのパターンで検索すればTRUEが返ります。「tanaka」のように@がない文字列ならFALSEです。</p>



<p>REGEXMATCH関数は<strong>Googleスプレッドシート独自の関数</strong>で、Excelには存在しません。Excelで同じことをするにはVBAが必要です。スプレッドシートなら関数だけで正規表現が使えるのが大きな強みですよ。</p>



<h3 class="wp-block-heading"><span id="toc2">「正規表現」って何？</span></h3>



<p>正規表現とは、文字列のパターンを記号で表すルールです。たとえば <code>[0-9]+</code> は「1文字以上の数字」を意味します。最初はとっつきにくく感じるかもしれません。でも、よく使うパターンは決まっています。この記事で紹介するパターンをコピーして使えばOKです。</p>



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



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



<pre class="wp-block-code"><code>=REGEXMATCH(テキスト, 正規表現)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th></tr></thead><tbody><tr><td>テキスト</td><td>必須</td><td>判定したい文字列またはセル参照</td></tr><tr><td>正規表現</td><td>必須</td><td>判定に使う正規表現パターン</td></tr></tbody></table></figure>



<p>戻り値はTRUEまたはFALSEです。テキストの中にパターンと一致する部分が<strong>1箇所でもあればTRUE</strong>を返します。なければFALSEです。</p>



<h3 class="wp-block-heading"><span id="toc5">正規表現の基本記号</span></h3>



<p>REGEXMATCH関数で使う正規表現の記号を押さえておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>記号</th><th>意味</th><th>例</th><th>マッチする文字列</th></tr></thead><tbody><tr><td><code>.</code></td><td>任意の1文字</td><td><code>a.c</code></td><td>abc, aXc, a1c</td></tr><tr><td><code>*</code></td><td>直前の文字が0回以上</td><td><code>ab*c</code></td><td>ac, abc, abbc</td></tr><tr><td><code>+</code></td><td>直前の文字が1回以上</td><td><code>ab+c</code></td><td>abc, abbc（acは不可）</td></tr><tr><td><code>?</code></td><td>直前の文字が0回か1回</td><td><code>ab?c</code></td><td>ac, abc</td></tr><tr><td><code>^</code></td><td>文字列の先頭</td><td><code>^東京</code></td><td>東京都、東京タワー</td></tr><tr><td><code>$</code></td><td>文字列の末尾</td><td><code>.com$</code></td><td>example.com</td></tr><tr><td><code>[abc]</code></td><td>いずれか1文字</td><td><code>[abc]</code></td><td>a, b, c</td></tr><tr><td><code>[0-9]</code></td><td>数字1文字</td><td><code>[0-9]+</code></td><td>123, 45</td></tr><tr><td><code>[a-zA-Z]</code></td><td>英字1文字</td><td><code>[a-zA-Z]+</code></td><td>Hello, abc</td></tr><tr><td><code>d</code></td><td>数字（[0-9]と同じ）</td><td><code>d{3}</code></td><td>123, 456</td></tr><tr><td><code>{n}</code></td><td>ちょうどn回</td><td><code>d{3}</code></td><td>123（12は不可）</td></tr><tr><td><code>{n,m}</code></td><td>n回以上m回以下</td><td><code>d{2,4}</code></td><td>12, 123, 1234</td></tr><tr><td>`</td><td>`</td><td>または</td><td>`東京</td><td>大阪`</td><td>東京、大阪</td></tr><tr><td><code>()</code></td><td>グループ化</td><td><code>(ab)+</code></td><td>ab, abab</td></tr></tbody></table></figure>



<p>ピリオド <code>.</code> やプラス <code>+</code> など、正規表現で特別な意味を持つ文字があります。これらをそのまま検索したい場合は、前にバックスラッシュ <code></code> を付けてください。たとえばピリオドそのものを探すなら <code>.</code> と書きます。</p>



<h2 class="wp-block-heading"><span id="toc6">基本的な使い方</span></h2>



<h3 class="wp-block-heading"><span id="toc7">特定の文字列が含まれるかを判定する</span></h3>



<p>セルA2に「東京都渋谷区」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;東京&quot;)   → TRUE（「東京」が含まれる）
=REGEXMATCH(A2, &quot;大阪&quot;)   → FALSE（「大阪」は含まれない）
=REGEXMATCH(A2, &quot;渋谷|新宿&quot;)  → TRUE（「渋谷」が含まれる）</code></pre>



<p>単純な文字列検索なら<a href="https://mashukabu.com/spreadsheet-search-function/">SEARCH関数</a>でもできます。REGEXMATCH関数の真価は、次のようなパターン検索にあります。</p>



<h3 class="wp-block-heading"><span id="toc8">数字が含まれるかを判定する</span></h3>



<p>セルA2に「ABC-123」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;[0-9]&quot;)     → TRUE（数字が含まれる）
=REGEXMATCH(A2, &quot;^[0-9]+$&quot;)  → FALSE（全体が数字ではない）</code></pre>



<p><code>[0-9]</code> は「数字が1文字でもあるか」の判定です。<code>^[0-9]+$</code> にすると「すべて数字か」の判定になります。<code>^</code>（先頭）と <code>$</code>（末尾）で全体を囲むのがポイントですよ。</p>



<h3 class="wp-block-heading"><span id="toc9">大文字・小文字を区別せずに判定する</span></h3>



<p>REGEXMATCH関数はデフォルトで<strong>大文字と小文字を区別</strong>します。区別せずに判定したいときは <code>(?i)</code> を先頭に付けます。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;tokyo&quot;)      → FALSE（小文字のtokyoは不一致）
=REGEXMATCH(A2, &quot;(?i)tokyo&quot;)  → TRUE（大文字小文字を無視してマッチ）</code></pre>



<p><code>(?i)</code> は「case-insensitive（大文字小文字を無視）」のフラグです。英語データを扱うときに便利ですね。</p>



<h2 class="wp-block-heading"><span id="toc10">実務で使えるパターン集</span></h2>



<h3 class="wp-block-heading"><span id="toc11">メールアドレスの形式チェック</span></h3>



<p>入力されたデータがメールアドレスの形式になっているかを判定します。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+.[a-zA-Z]{2,}$&quot;)</code></pre>



<p>この正規表現は「英数字@英数字.英字2文字以上」のパターンです。完璧な検証ではありませんが、入力ミスの検出には十分使えます。</p>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th><th>理由</th></tr></thead><tbody><tr><td>tanaka@example.com</td><td>TRUE</td><td>正しい形式</td></tr><tr><td>tanaka@example</td><td>FALSE</td><td>ドメインにピリオドがない</td></tr><tr><td>tanaka.example.com</td><td>FALSE</td><td>@がない</td></tr><tr><td>@example.com</td><td>FALSE</td><td>ローカル部分がない</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc12">電話番号の形式チェック</span></h3>



<p>日本の電話番号パターン（ハイフンあり・なし両対応）を判定します。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;^0d{1,4}-?d{1,4}-?d{3,4}$&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>セルの値</th><th>結果</th><th>理由</th></tr></thead><tbody><tr><td>03-1234-5678</td><td>TRUE</td><td>固定電話（ハイフンあり）</td></tr><tr><td>09012345678</td><td>TRUE</td><td>携帯電話（ハイフンなし）</td></tr><tr><td>090-1234-5678</td><td>TRUE</td><td>携帯電話（ハイフンあり）</td></tr><tr><td>1234-5678</td><td>FALSE</td><td>先頭が0でない</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc13">郵便番号の形式チェック</span></h3>



<p>「123-4567」または「1234567」の形式を判定します。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;^d{3}-?d{4}$&quot;)</code></pre>



<p><code>-?</code> は「ハイフンが0回か1回」を意味します。ハイフンあり・なしの両方に対応できるのが便利ですね。</p>



<h3 class="wp-block-heading"><span id="toc14">IF関数と組み合わせてラベルを付ける</span></h3>



<p>REGEXMATCH関数はTRUE/FALSEを返します。<a href="https://mashukabu.com/spreadsheet-if-function/">IF関数</a>と組み合わせれば条件分岐に使えます。</p>



<pre class="wp-block-code"><code>=IF(REGEXMATCH(A2, &quot;@&quot;), &quot;メールアドレス&quot;, &quot;その他&quot;)</code></pre>



<p><a href="https://mashukabu.com/spreadsheet-filter-function/">FILTER関数</a>と組み合わせれば、パターンに合致する行だけの抽出も可能です。</p>



<pre class="wp-block-code"><code>=FILTER(A2:B10, REGEXMATCH(A2:A10, &quot;東京|大阪&quot;))</code></pre>



<p>この数式は、A列に「東京」または「大阪」を含む行だけをA:B列から抽出します。</p>



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



<figure class="wp-block-table"><table><thead><tr><th>エラー</th><th>原因</th><th>対処法</th></tr></thead><tbody><tr><td>#VALUE!</td><td>テキストが数値</td><td><code>=REGEXMATCH(TEXT(A2,"0"), "パターン")</code> で文字列に変換</td></tr><tr><td>#VALUE!</td><td>テキストが空セル</td><td><code>=IF(A2="", FALSE, REGEXMATCH(A2, "パターン"))</code> で空チェック</td></tr><tr><td>#REF!</td><td>正規表現の構文エラー</td><td>括弧の閉じ忘れ・エスケープ漏れを確認</td></tr><tr><td>期待と逆の結果</td><td>部分一致と完全一致の混同</td><td>完全一致なら <code>^パターン$</code> で囲む</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc16">数値セルで#VALUE!エラーになるケース</span></h3>



<p>REGEXMATCH関数の第1引数は<strong>文字列</strong>が必要です。セルに数値が入っている場合は#VALUE!エラーになります。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;d+&quot;)           → A2が数値だと #VALUE!
=REGEXMATCH(TEXT(A2, &quot;0&quot;), &quot;d+&quot;) → TEXT関数で文字列に変換すればOK</code></pre>



<p>数値にパターン判定をしたい場合は、<a href="https://mashukabu.com/spreadsheet-text-function/">TEXT関数</a>で文字列に変換してから渡しましょう。</p>



<h3 class="wp-block-heading"><span id="toc17">正規表現の特殊文字をエスケープし忘れるケース</span></h3>



<p>ピリオド <code>.</code>、括弧 <code>()</code>、プラス <code>+</code> などは正規表現の特殊文字です。これらの文字そのものを検索したい場合は <code></code> でエスケープしてください。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;.&quot;)     → 任意の1文字にマッチ（ほぼ常にTRUE）
=REGEXMATCH(A2, &quot;.&quot;)    → ピリオドそのものにマッチ</code></pre>



<h2 class="wp-block-heading"><span id="toc18">REGEXEXTRACT・REGEXREPLACEとの使い分け</span></h2>



<p>スプレッドシートには正規表現を使う関数が3つあります。目的で使い分けましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>目的</th><th>戻り値</th><th>使用例</th></tr></thead><tbody><tr><td>REGEXMATCH</td><td>パターンに<strong>一致するか判定</strong></td><td>TRUE / FALSE</td><td>入力チェック、条件分岐</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-regexextract-function/">REGEXEXTRACT</a></td><td>パターンに一致する部分を<strong>抽出</strong></td><td>一致した文字列</td><td>メールアドレスからドメイン抽出</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-regexreplace-function/">REGEXREPLACE</a></td><td>パターンに一致する部分を<strong>置換</strong></td><td>置換後の文字列</td><td>電話番号のハイフン除去</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc19">具体例で比較</span></h3>



<p>セルA2に「注文番号: ORD-2024-0123」が入っているとします。</p>



<pre class="wp-block-code"><code>=REGEXMATCH(A2, &quot;ORD-d{4}-d{4}&quot;)
  → TRUE（注文番号パターンに一致するか判定）

=REGEXEXTRACT(A2, &quot;ORD-d{4}-d{4}&quot;)
  → &quot;ORD-2024-0123&quot;（注文番号部分を抽出）

=REGEXREPLACE(A2, &quot;ORD-&quot;, &quot;&quot;)
  → &quot;注文番号: 2024-0123&quot;（「ORD-」を除去）</code></pre>



<p><strong>判定</strong>はREGEXMATCH、<strong>抽出</strong>はREGEXEXTRACT、<strong>置換</strong>はREGEXREPLACEと覚えておきましょう。</p>



<h2 class="wp-block-heading"><span id="toc20">SEARCH・FIND関数との違い</span></h2>



<p><a href="https://mashukabu.com/spreadsheet-search-function/">SEARCH関数</a>や<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>でも文字列検索はできます。REGEXMATCH関数との違いを整理しましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>比較項目</th><th>REGEXMATCH</th><th>SEARCH</th><th>FIND</th></tr></thead><tbody><tr><td>戻り値</td><td>TRUE/FALSE</td><td>文字位置（数値）</td><td>文字位置（数値）</td></tr><tr><td>正規表現</td><td>使える</td><td>使えない</td><td>使えない</td></tr><tr><td>ワイルドカード</td><td>不要（正規表現で代替）</td><td><code>*</code> <code>?</code> が使える</td><td>使えない</td></tr><tr><td>大文字小文字</td><td>区別する（<code>(?i)</code> で無視可）</td><td>区別しない</td><td>区別する</td></tr><tr><td>不一致時</td><td>FALSE</td><td>#VALUE!エラー</td><td>#VALUE!エラー</td></tr><tr><td>Excel互換</td><td>なし（Sheets独自）</td><td>あり</td><td>あり</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc21">どれを使うべき？</span></h3>



<ul class="wp-block-list"><li><strong>単純な文字検索</strong>（「東京」が含まれるか）→ <a href="https://mashukabu.com/spreadsheet-search-function/">SEARCH関数</a> + ISNUMBER で十分</li><li><strong>パターン検索</strong>（「数字3桁-数字4桁」の形式か）→ <strong>REGEXMATCH関数</strong>一択</li><li><strong>大文字小文字を厳密に区別した検索</strong> → <a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a></li></ul>



<p>正規表現が使えるかどうかが最大の違いです。「特定の文字があるか」だけならSEARCH/FINDで十分です。「パターンに合致するか」を判定したいならREGEXMATCH関数を選びましょう。</p>



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



<p>REGEXMATCH関数は、正規表現でパターン判定ができるスプレッドシート独自の関数です。</p>



<ul class="wp-block-list"><li><strong>基本</strong>: <code>=REGEXMATCH(テキスト, 正規表現)</code> でTRUE/FALSEを返す</li><li><strong>実務活用</strong>: メールアドレス・電話番号・郵便番号の入力チェックに最適</li><li><strong>使い分け</strong>: 判定はREGEXMATCH、抽出はREGEXEXTRACT、置換はREGEXREPLACE</li><li><strong>注意点</strong>: 数値セルはTEXT関数で文字列に変換してから渡す</li></ul>



<p>SEARCH/FIND関数では対応できないパターン判定が必要なとき、ぜひ活用してみてください。正規表現は最初はとっつきにくいかもしれません。でも、この記事のパターンをコピーして使うだけでも業務効率がぐっと上がりますよ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-regexmatch-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのREPLACE関数の使い方｜位置指定で文字列を置換する方法</title>
		<link>https://mashukabu.com/spreadsheet-replace-function/</link>
					<comments>https://mashukabu.com/spreadsheet-replace-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Thu, 19 Mar 2026 10:41:10 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[REPLACE関数]]></category>
		<category><![CDATA[SUBSTITUTE関数]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[文字列置換]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4386</guid>

					<description><![CDATA[スプレッドシートのREPLACE関数の使い方を基本から解説。位置指定で文字列を置換する方法、SUBSTITUTEとの違い、FIND関数との組み合わせ応用まで実務例付きでわかります。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートで「3文字目から2文字だけ置き換えたい」と思ったことはありませんか？商品コードの一部を変更したい、電話番号の市外局番だけ差し替えたい。<a href="https://mashukabu.com/spreadsheet-substitute-function/">SUBSTITUTE関数</a>では文字列を指定して置換しますが、「何文字目から何文字分」という位置で指定したい場面もありますよね。</p>



<p>REPLACE関数を使えば、位置と文字数を指定してピンポイントで置換できます。この記事ではスプレッドシートでのREPLACE関数の基本から、実務での活用パターン、<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>との組み合わせ応用まで丁寧に解説します。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-7" checked><label class="toc-title" for="toc-checkbox-7">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">スプレッドシートのREPLACE関数とは？位置指定で文字列を置換する関数</a><ol><li><a href="#toc2" tabindex="0">基本構文と引数</a></li></ol></li><li><a href="#toc3" tabindex="0">REPLACE関数の基本的な使い方</a><ol><li><a href="#toc4" tabindex="0">文字数を0にすると「挿入」になる</a></li><li><a href="#toc5" tabindex="0">開始位置以降をすべて置換する</a></li></ol></li><li><a href="#toc6" tabindex="0">REPLACE関数の実務活用パターン</a><ol><li><a href="#toc7" tabindex="0">電話番号の市外局番を置き換える</a></li><li><a href="#toc8" tabindex="0">固定フォーマットの年度部分だけ変更する</a></li><li><a href="#toc9" tabindex="0">個人情報の一部をマスクする（伏せ字処理）</a></li></ol></li><li><a href="#toc10" tabindex="0">FIND関数と組み合わせて動的に位置を指定する</a><ol><li><a href="#toc11" tabindex="0">メールアドレスのドメイン部分を置き換える</a></li><li><a href="#toc12" tabindex="0">区切り文字の前半だけを差し替える</a></li></ol></li><li><a href="#toc13" tabindex="0">REPLACE関数とSUBSTITUTE関数の使い分け</a><ol><li><a href="#toc14" tabindex="0">比較表</a></li><li><a href="#toc15" tabindex="0">どちらを使うか迷ったら</a></li></ol></li><li><a href="#toc16" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc17" tabindex="0">#VALUE!エラーが出る</a></li><li><a href="#toc18" tabindex="0">開始位置が文字数を超えている</a></li><li><a href="#toc19" tabindex="0">空セルを渡した場合</a></li></ol></li><li><a href="#toc20" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">スプレッドシートのREPLACE関数とは？位置指定で文字列を置換する関数</span></h2>



<p>REPLACE関数は、文字列の中の<strong>指定した位置から指定した文字数分を別の文字に置き換える</strong>関数です。読み方は「リプレース」。英語の「Replace（置き換える）」がそのまま名前になっています。</p>



<p>たとえば「ABCDE」の2文字目から3文字分を「XY」に置き換えると「AXYE」になります。位置と長さで置換範囲を決めるので、置き換えたい文字の内容を知らなくても使えるのがポイントです。</p>



<h3 class="wp-block-heading"><span id="toc2">基本構文と引数</span></h3>



<pre class="wp-block-code"><code>=REPLACE(テキスト, 開始位置, 文字数, 新しいテキスト)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th></tr></thead><tbody><tr><td>テキスト</td><td>必須</td><td>置換対象のセルまたは文字列</td></tr><tr><td>開始位置</td><td>必須</td><td>置き換えを始める位置（1から数える）</td></tr><tr><td>文字数</td><td>必須</td><td>置き換える文字の数</td></tr><tr><td>新しいテキスト</td><td>必須</td><td>置き換え後の文字列</td></tr></tbody></table></figure>



<p>4つの引数はすべて必須です。<a href="https://mashukabu.com/spreadsheet-substitute-function/">SUBSTITUTE関数</a>は省略可能な引数がありますが、REPLACE関数は1つも省略できません。</p>



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



<p>セルA2に「ABCDEFG」が入っているとします。3文字目から2文字分を「XX」に置き換えてみましょう。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 3, 2, &quot;XX&quot;)  → 「ABXXEFG」</code></pre>



<p>3文字目の「C」と4文字目の「D」が「XX」に置き換わりました。開始位置は1始まりなので、先頭が1、次が2と数えます。</p>



<h3 class="wp-block-heading"><span id="toc4">文字数を0にすると「挿入」になる</span></h3>



<p>文字数に0を指定すると、元の文字を削除せずに新しいテキストを挿入できます。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 3, 0, &quot;-&quot;)  → 「AB-CDEFG」</code></pre>



<p>3文字目の「C」の前にハイフンが挿入されました。文字を消さずに割り込ませたい場合に便利です。</p>



<h3 class="wp-block-heading"><span id="toc5">開始位置以降をすべて置換する</span></h3>



<p>文字数を大きめに指定すると、開始位置から末尾までを置き換えられます。文字数が残りの文字数を超えてもエラーにはなりません。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 4, 100, &quot;XYZ&quot;)  → 「ABCXYZ」</code></pre>



<p>4文字目以降の「DEFG」が「XYZ」に置き換わりました。残りが4文字なのに文字数を100にしても問題ありません。「この位置から後ろは全部変えたい」ときに使えるテクニックです。</p>



<h2 class="wp-block-heading"><span id="toc6">REPLACE関数の実務活用パターン</span></h2>



<h3 class="wp-block-heading"><span id="toc7">電話番号の市外局番を置き換える</span></h3>



<p>電話番号の先頭3桁（市外局番）を別の番号に差し替える例です。A2に「03-1234-5678」が入っています。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 1, 2, &quot;06&quot;)  → 「06-1234-5678」</code></pre>



<p>1文字目から2文字分、つまり「03」を「06」に置き換えました。市外局番の桁数が決まっているので、位置指定のREPLACE関数がぴったりです。</p>



<h3 class="wp-block-heading"><span id="toc8">固定フォーマットの年度部分だけ変更する</span></h3>



<p>管理番号が「2024-A001」のように「年度-連番」のフォーマットになっているとします。年度部分だけを更新する場合です。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 1, 4, &quot;2025&quot;)  → 「2025-A001」</code></pre>



<p>先頭4文字の「2024」を「2025」に置き換えました。連番部分はそのままなので、年度切り替え時のデータ更新が数式1つで済みます。</p>



<h3 class="wp-block-heading"><span id="toc9">個人情報の一部をマスクする（伏せ字処理）</span></h3>



<p>名前や電話番号の一部を「***」で隠す伏せ字処理にもREPLACE関数は役立ちます。A2に「09012345678」（携帯番号）が入っています。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 4, 4, &quot;****&quot;)  → 「090****5678」</code></pre>



<p>4文字目から4文字分を「****」に置き換えました。先頭3桁と末尾4桁は残しつつ、中間をマスクできます。個人情報を含む一覧を配布するときに便利ですよ。</p>



<p>名前の伏せ字にも使えます。A2に「山田太郎」が入っている場合です。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 2, 1, &quot;○&quot;)  → 「山○太郎」</code></pre>



<p>2文字目の「田」を「○」に置き換えて、苗字の一部を伏せました。</p>



<h2 class="wp-block-heading"><span id="toc10">FIND関数と組み合わせて動的に位置を指定する</span></h2>



<p>ここまでの例は、置き換える位置が「先頭から何文字目」と決まっているケースでした。しかし実務では、データによって位置が変わることもありますよね。</p>



<p>そんなときは<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>で位置を動的に取得してREPLACEに渡します。</p>



<h3 class="wp-block-heading"><span id="toc11">メールアドレスのドメイン部分を置き換える</span></h3>



<p>A2に「user@old-domain.com」が入っています。「@」より後ろを新しいドメインに差し替えたい場合です。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, FIND(&quot;@&quot;, A2), LEN(A2) - FIND(&quot;@&quot;, A2) + 1, &quot;@new-domain.com&quot;)</code></pre>



<p>結果は「user@new-domain.com」です。ちょっとむずかしく見えますが、やっていることはシンプルです。</p>



<ol class="wp-block-list"><li><code>FIND("@", A2)</code> → 「@」の位置（5）を取得</li><li><code>LEN(A2) - FIND("@", A2) + 1</code> → 「@」以降の文字数（16）を計算</li><li>REPLACEで5文字目から16文字分を新ドメインに置換</li></ol>



<p>FIND関数が「@」の位置を自動で調べてくれるので、ユーザー名の長さがバラバラでも正しく動作します。</p>



<h3 class="wp-block-heading"><span id="toc12">区切り文字の前半だけを差し替える</span></h3>



<p>A2に「ABC-12345」が入っていて、ハイフンより前の部分を「XYZ」に変えたい場合です。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 1, FIND(&quot;-&quot;, A2) - 1, &quot;XYZ&quot;)  → 「XYZ-12345」</code></pre>



<p><code>FIND("-", A2) - 1</code>でハイフンの手前までの文字数を計算し、先頭からその分だけ置き換えています。<a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a>で切り出して結合する方法もありますが、REPLACEなら1つの数式で完結しますよ。</p>



<h2 class="wp-block-heading"><span id="toc13">REPLACE関数とSUBSTITUTE関数の使い分け</span></h2>



<p>スプレッドシートの置換系関数で一番迷うのが、REPLACE関数と<a href="https://mashukabu.com/spreadsheet-substitute-function/">SUBSTITUTE関数</a>の使い分けです。ひとことで言えば、<strong>SUBSTITUTEは「文字」で指定、REPLACEは「位置」で指定</strong>です。</p>



<h3 class="wp-block-heading"><span id="toc14">比較表</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>REPLACE</th><th>SUBSTITUTE</th></tr></thead><tbody><tr><td>置換の指定方法</td><td>位置と文字数（何文字目から何文字分）</td><td>文字列検索（何という文字か）</td></tr><tr><td>引数の数</td><td>4つ（すべて必須）</td><td>3〜4つ（第4引数は省略可）</td></tr><tr><td>複数箇所の置換</td><td>1か所のみ</td><td>省略で全置換、第4引数でN番目のみ</td></tr><tr><td>大文字/小文字</td><td>区別しない（位置指定のため無関係）</td><td>区別する</td></tr><tr><td>挿入（文字数0）</td><td>可能</td><td>不可</td></tr><tr><td>向いている場面</td><td>固定フォーマット・伏せ字・位置が決まっている</td><td>特定の文字を検索して全置換</td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc15">どちらを使うか迷ったら</span></h3>



<p>判断基準はシンプルです。</p>



<ul class="wp-block-list"><li><strong>置き換えたい文字の「内容」がわかっている</strong> → SUBSTITUTE</li><li><strong>置き換えたい文字の「位置」がわかっている</strong> → REPLACE</li></ul>



<p>「ハイフンを全部消したい」ならSUBSTITUTEです。「3文字目から2文字を変えたい」ならREPLACEです。</p>



<p>実務で使う頻度はSUBSTITUTEのほうが圧倒的に高いです。REPLACEは「固定フォーマットの一部だけ変えたい」「伏せ字にしたい」など、位置が決まっている場面で活躍します。</p>



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



<h3 class="wp-block-heading"><span id="toc17">#VALUE!エラーが出る</span></h3>



<p>開始位置に0以下の数値を指定するとエラーになります。REPLACE関数の開始位置は<strong>1始まり</strong>です。</p>



<pre class="wp-block-code"><code>=REPLACE(A2, 0, 2, &quot;XX&quot;)  → #VALUE!エラー
=REPLACE(A2, 1, 2, &quot;XX&quot;)  → 正常動作</code></pre>



<p>プログラミングに慣れている方は0始まりで考えがちですが、スプレッドシートの文字列関数は1始まりです。<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>や<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>も同じルールですよ。</p>



<h3 class="wp-block-heading"><span id="toc18">開始位置が文字数を超えている</span></h3>



<p>開始位置がテキストの文字数より大きいと、末尾に新しいテキストが追加されます。エラーにはなりません。</p>



<pre class="wp-block-code"><code>=REPLACE(&quot;ABC&quot;, 10, 2, &quot;XY&quot;)  → 「ABCXY」</code></pre>



<p>意図しない結果になるので、開始位置は元のテキストの文字数以内にしてくださいね。</p>



<h3 class="wp-block-heading"><span id="toc19">空セルを渡した場合</span></h3>



<p>テキストが空セルの場合、新しいテキストだけが返ります。</p>



<pre class="wp-block-code"><code>=REPLACE(&quot;&quot;, 1, 0, &quot;ABC&quot;)  → 「ABC」</code></pre>



<p>エラーにはなりませんが、元データが空なのに結果が出力される点に注意してください。空セルチェックにはIF関数と組み合わせると安全です。</p>



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



<p>REPLACE関数の要点を整理します。</p>



<figure class="wp-block-table"><table><thead><tr><th>ポイント</th><th>内容</th></tr></thead><tbody><tr><td>基本構文</td><td><code>=REPLACE(テキスト, 開始位置, 文字数, 新しいテキスト)</code></td></tr><tr><td>引数</td><td>4つすべて必須</td></tr><tr><td>開始位置</td><td>1始まり（0はエラー）</td></tr><tr><td>文字数0</td><td>削除せず挿入として機能</td></tr><tr><td>文字数超過</td><td>エラーにならず末尾まで置換</td></tr><tr><td>SUBSTITUTEとの違い</td><td>SUBSTITUTE=文字指定、REPLACE=位置指定</td></tr></tbody></table></figure>



<p>REPLACE関数は「何文字目から何文字分」と位置で指定する置換関数です。固定フォーマットの一部変更や個人情報のマスクなど、位置が決まっている場面で大活躍します。</p>



<p>まずは市外局番の差し替えや伏せ字処理から試してみてください。FIND関数と組み合わせれば、位置が動的に変わるデータにも対応できるようになりますよ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-replace-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのSEARCH関数｜大文字小文字を無視して検索</title>
		<link>https://mashukabu.com/spreadsheet-search-function/</link>
					<comments>https://mashukabu.com/spreadsheet-search-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Thu, 19 Mar 2026 09:29:36 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[ISNUMBER]]></category>
		<category><![CDATA[SEARCH関数]]></category>
		<category><![CDATA[ワイルドカード]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4283</guid>

					<description><![CDATA[スプレッドシートのSEARCH関数は、大文字と小文字を区別せずに文字の位置を返す関数です。ワイルドカード（*/?）が使えるのがFINDとの大きな違い。ISNUMBER+SEARCHでのフラグ立てや、LEFT・MIDとの組み合わせ実務パターンを解説します。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートで英語混じりのデータを扱っていると、表記のバラつきに悩みませんか？大文字・小文字が入り混じって、検索しづらいと感じたことはありませんか？手作業で目視チェックするのは非効率ですし、データが多いほどミスも増えますよね。</p>



<p>SEARCH関数を使えば、大文字・小文字を気にせず文字の位置を検索できます。この記事ではスプレッドシートのSEARCH関数を基本から丁寧に解説します。ワイルドカード検索・実務での活用パターン・エラー対処法までカバーしますね。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-8" checked><label class="toc-title" for="toc-checkbox-8">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">SEARCH関数とは？大文字小文字を無視して文字位置を検索する関数</a><ol><li><a href="#toc2" tabindex="0">FINDとの違いをひとことで言うと</a></li></ol></li><li><a href="#toc3" tabindex="0">SEARCH関数の書き方（構文と引数）</a><ol><li><a href="#toc4" tabindex="0">基本構文</a></li><li><a href="#toc5" tabindex="0">第3引数（開始位置）の使いどころ</a></li></ol></li><li><a href="#toc6" tabindex="0">基本的な使い方</a><ol><li><a href="#toc7" tabindex="0">英語混じりのデータで大文字小文字を無視して検索する</a></li><li><a href="#toc8" tabindex="0">開始位置を指定して2回目以降の出現位置を探す</a></li></ol></li><li><a href="#toc9" tabindex="0">SEARCH関数とFIND関数の違い</a><ol><li><a href="#toc10" tabindex="0">比較表（大文字小文字の区別・ワイルドカード・エラー時の挙動）</a></li><li><a href="#toc11" tabindex="0">どちらを使うか迷ったときの判断基準</a></li></ol></li><li><a href="#toc12" tabindex="0">ワイルドカードの使い方（*と?）</a><ol><li><a href="#toc13" tabindex="0">*（アスタリスク）で0文字以上の任意文字列にマッチ</a></li><li><a href="#toc14" tabindex="0">?（クエスチョン）で1文字だけにマッチ</a></li><li><a href="#toc15" tabindex="0">実務例：商品名のパターン検索</a></li></ol></li><li><a href="#toc16" tabindex="0">実務での活用例</a><ol><li><a href="#toc17" tabindex="0">ISNUMBER+SEARCHでキーワード含有フラグを立てる</a></li><li><a href="#toc18" tabindex="0">MID+SEARCHで特定区切り文字以降を取り出す</a></li><li><a href="#toc19" tabindex="0">IF+IFERRORで「含む／含まない」を安全に判定する</a></li></ol></li><li><a href="#toc20" tabindex="0">エラー（#VALUE!）の原因と対処法</a><ol><li><a href="#toc21" tabindex="0">エラーの原因</a></li><li><a href="#toc22" tabindex="0">IFERRORで安全に処理する</a></li></ol></li><li><a href="#toc23" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">SEARCH関数とは？大文字小文字を無視して文字位置を検索する関数</span></h2>



<p>SEARCH関数は、文字列の中から<strong>特定の文字が何文字目にあるかを返す</strong>関数です。読み方は「サーチ」。英語の「Search（検索する）」がそのまま名前になっています。</p>



<p>たとえば「Apple」という文字列に対して「apple」で検索しても、ちゃんと1文字目と判定してくれます。<strong>大文字と小文字を区別しない</strong>のがSEARCH関数の最大の特徴です。</p>



<p>さらに、ワイルドカード（<code>*</code> や <code>?</code>）を使った曖昧検索にも対応しています。「パターンに合う文字列がどこにあるか」を調べられるのは、SEARCH関数だけの強みですよ。</p>



<h3 class="wp-block-heading"><span id="toc2">FINDとの違いをひとことで言うと</span></h3>



<p>スプレッドシートには文字位置を調べる関数がもう1つあります。<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>です。</p>



<p>違いはシンプルで、<strong>FINDは大文字小文字を区別する</strong>のに対し、<strong>SEARCHは区別しない</strong>という点です。さらにSEARCHはワイルドカードが使えます。詳しい比較は後のセクションで解説しますね。</p>



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



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



<pre class="wp-block-code"><code>=SEARCH(検索文字列, 対象テキスト, [開始位置])</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</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>何文字目から検索を始めるか（省略時は1）</td></tr></tbody></table></figure>



<p>戻り値は「検索文字列が最初に見つかった位置」の数値です。1文字目が「1」なので、0始まりではありません。</p>



<h3 class="wp-block-heading"><span id="toc5">第3引数（開始位置）の使いどころ</span></h3>



<p>開始位置を指定すると、途中から検索を開始できます。同じ文字が複数回出てくるテキストで「2番目の出現位置」を調べたいときに便利です。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;-&quot;, &quot;ABC-001-RED&quot;)      → 4（最初のハイフン）
=SEARCH(&quot;-&quot;, &quot;ABC-001-RED&quot;, 5)   → 8（2番目のハイフン）</code></pre>



<p>1回目のSEARCHで最初のハイフン位置（4）を取得します。その次の位置（5）から検索を再開する仕組みです。区切り文字が複数あるデータを処理するときに活躍しますよ。</p>



<h2 class="wp-block-heading"><span id="toc6">基本的な使い方</span></h2>



<h3 class="wp-block-heading"><span id="toc7">英語混じりのデータで大文字小文字を無視して検索する</span></h3>



<p>セルA2に「Apple Juice」が入っているとします。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;apple&quot;, A2)   → 1（大文字Aでも小文字aでもマッチ）
=SEARCH(&quot;JUICE&quot;, A2)   → 7（大文字で検索してもヒットする）
=SEARCH(&quot;e&quot;, A2)       → 5（最初のeは5文字目）</code></pre>



<p>「apple」で検索しても「Apple」にマッチするのがポイントです。ユーザーが入力した表記がバラバラでも、SEARCH関数なら問題なく位置を取得できます。</p>



<p>ただし<strong>全角と半角は区別される</strong>点に注意してください。全角の「Ａ」と半角の「A」は別の文字として扱われます。</p>



<h3 class="wp-block-heading"><span id="toc8">開始位置を指定して2回目以降の出現位置を探す</span></h3>



<p>セルA2に「tanaka@example.com」が入っています。「a」が複数回出てくるデータで、2番目の「a」の位置を調べてみましょう。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;a&quot;, A2)       → 2（1番目のa）
=SEARCH(&quot;a&quot;, A2, 3)    → 4（2番目のa：3文字目以降で最初に見つかるa）
=SEARCH(&quot;a&quot;, A2, 5)    → 6（3番目のa：5文字目以降で最初に見つかるa）</code></pre>



<p>開始位置を変えるだけで、同じ文字の出現位置を順番に取得できます。<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>と組み合わせれば、区切り文字間のテキスト抽出にも応用できますよ。</p>



<h2 class="wp-block-heading"><span id="toc9">SEARCH関数とFIND関数の違い</span></h2>



<h3 class="wp-block-heading"><span id="toc10">比較表（大文字小文字の区別・ワイルドカード・エラー時の挙動）</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>SEARCH</th><th>FIND</th></tr></thead><tbody><tr><td>大文字/小文字</td><td><strong>区別しない</strong></td><td>区別する</td></tr><tr><td>ワイルドカード</td><td><code>*</code>（任意の文字列）<code>?</code>（任意の1文字）が使える</td><td>使えない</td></tr><tr><td>見つからない場合</td><td>#VALUE!エラー</td><td>#VALUE!エラー</td></tr><tr><td>構文</td><td><code>=SEARCH(検索文字列, 対象テキスト, [開始位置])</code></td><td><code>=FIND(検索文字列, テキスト, [開始位置])</code></td></tr></tbody></table></figure>



<p>エラー時の挙動は同じです。どちらもIFERROR（エラー時に代替値を返す関数）で対処できます。</p>



<h3 class="wp-block-heading"><span id="toc11">どちらを使うか迷ったときの判断基準</span></h3>



<p>使い分けのポイントは3つだけです。</p>



<ul class="wp-block-list"><li><strong>大文字小文字を区別したい</strong> → <a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a></li><li><strong>区別しなくてよい</strong> → SEARCH関数</li><li><strong>ワイルドカードで曖昧検索したい</strong> → SEARCH関数</li></ul>



<p>実務では「@」「/」「-」のような記号の位置を調べる場面が多いです。記号には大文字小文字がないので、FINDでもSEARCHでも同じ結果になります。</p>



<p>迷ったらSEARCHを選んでおくのがおすすめです。大文字小文字の違いでエラーになるリスクを避けられますよ。</p>



<h2 class="wp-block-heading"><span id="toc12">ワイルドカードの使い方（*と?）</span></h2>



<p>SEARCH関数だけが使える機能がワイルドカードです。<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>ではワイルドカードは使えません。</p>



<h3 class="wp-block-heading"><span id="toc13">*（アスタリスク）で0文字以上の任意文字列にマッチ</span></h3>



<p><code>*</code> は「何文字でもOK（0文字以上）」を意味します。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;A*Z&quot;, &quot;A123Z-test&quot;)   → 1（AではじまりZで終わるパターンにマッチ）
=SEARCH(&quot;re*t&quot;, &quot;report&quot;)      → 1（reではじまりtで終わるパターン）</code></pre>



<p>「A*Z」は「Aで始まってZで終わる任意の文字列」です。間に何文字あってもマッチします。</p>



<h3 class="wp-block-heading"><span id="toc14">?（クエスチョン）で1文字だけにマッチ</span></h3>



<p><code>?</code> は「ちょうど1文字」を意味します。</p>



<pre class="wp-block-code"><code>=SEARCH(&quot;A?C&quot;, &quot;ABC-test&quot;)    → 1（AとCの間に1文字あるパターン）
=SEARCH(&quot;A??C&quot;, &quot;AB1C-test&quot;)  → 1（AとCの間に2文字あるパターン）</code></pre>



<p><code>?</code> を並べた数だけ、任意の文字にマッチします。文字数が決まっている場合に便利です。</p>



<p>なお、リテラルの <code><em></code> や <code>?</code> そのものを検索したいときは、チルダ（<code>~</code>）でエスケープします。<code>~</em></code> で「*という文字自体」を検索できますよ。</p>



<h3 class="wp-block-heading"><span id="toc15">実務例：商品名のパターン検索</span></h3>



<p>商品コードが「先頭2文字がカテゴリ＋数字3桁」のような形式で、パターンにマッチするか調べたい場面を考えてみましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>A列（商品名）</th><th>数式</th><th>結果</th></tr></thead><tbody><tr><td>EL-001 電子部品</td><td><code>=ISNUMBER(SEARCH("EL-???", A2))</code></td><td>TRUE</td></tr><tr><td>EL-12 電子部品</td><td><code>=ISNUMBER(SEARCH("EL-???", A3))</code></td><td>FALSE</td></tr><tr><td>MK-500 機械部品</td><td><code>=ISNUMBER(SEARCH("EL-???", A4))</code></td><td>FALSE</td></tr></tbody></table></figure>



<p>ISNUMBER（値が数値かどうか判定する関数）でSEARCHを囲むと、TRUE / FALSEで判定できます。「EL-???」は「EL-の後ろにちょうど3文字」を意味するので、「EL-12」のように2文字だとFALSEになります。</p>



<h2 class="wp-block-heading"><span id="toc16">実務での活用例</span></h2>



<h3 class="wp-block-heading"><span id="toc17">ISNUMBER+SEARCHでキーワード含有フラグを立てる</span></h3>



<p>データの中に特定のキーワードが含まれるかどうか判定するパターンです。分類やフラグ付けに使えます。</p>



<pre class="wp-block-code"><code>=IF(ISNUMBER(SEARCH(&quot;東京&quot;, A2)), &quot;含む&quot;, &quot;含まない&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>A列（住所）</th><th>結果</th></tr></thead><tbody><tr><td>東京都新宿区</td><td>含む</td></tr><tr><td>大阪府大阪市</td><td>含まない</td></tr><tr><td>東京都渋谷区</td><td>含む</td></tr></tbody></table></figure>



<p>SEARCH関数は文字列が見つかると位置（数値）を返します。ISNUMBERで「数値が返ったか」を判定すれば、含む・含まないの振り分けができます。大文字小文字を気にしないので、英語キーワードの判定にも安心して使えますよ。</p>



<figure class="wp-block-image"><img decoding="async" src="https://mashukabu.com/wp-content/uploads/2026/03/01_result_isnumber-search.png" alt="01 result isnumber search" /></figure>



<h3 class="wp-block-heading"><span id="toc18">MID+SEARCHで特定区切り文字以降を取り出す</span></h3>



<p>セルA2に「tanaka@example.com」が入っています。@より後ろの「example.com」を取り出してみましょう。</p>



<pre class="wp-block-code"><code>=MID(A2, SEARCH(&quot;@&quot;, A2)+1, LEN(A2))</code></pre>



<ol class="wp-block-list"><li><code>SEARCH("@", A2)</code> → @は7文字目</li><li>7 + 1 = 8（@の次の位置）</li><li><code>LEN(A2)</code> → 19（十分大きい文字数を指定）</li><li><code>MID(A2, 8, 19)</code> → 8文字目から末尾までで「example.com」</li></ol>



<p>!<a href="https://mashukabu.com/_images/spreadsheet-search-function/02_result_mid-search.png/">_images/spreadsheet-search-function/02_result_mid-search.png</a></p>



<p><a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>の第3引数にLEN（文字数を返す関数）で全体の長さを渡しておくと、区切り文字以降すべてを取得できます。</p>



<p>逆に@より前を取り出すなら、<a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a>を使います。</p>



<pre class="wp-block-code"><code>=LEFT(A2, SEARCH(&quot;@&quot;, A2)-1)  → 「tanaka」</code></pre>



<h3 class="wp-block-heading"><span id="toc19">IF+IFERRORで「含む／含まない」を安全に判定する</span></h3>



<p>SEARCH関数は文字列が見つからないと#VALUE!エラーを返します。エラーを想定してIFERRORで囲むのが実務の定番です。</p>



<pre class="wp-block-code"><code>=IF(IFERROR(SEARCH(&quot;pdf&quot;, A2), 0) &gt; 0, &quot;PDF&quot;, &quot;その他&quot;)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>A列（ファイル名）</th><th>結果</th></tr></thead><tbody><tr><td>report.pdf</td><td>PDF</td></tr><tr><td>data.xlsx</td><td>その他</td></tr><tr><td>manual.PDF</td><td>PDF</td></tr></tbody></table></figure>



<p>SEARCH関数は大文字小文字を区別しないので、「pdf」で検索しても「.PDF」にマッチします。拡張子の表記ゆれを気にせず判定できるのがうれしいポイントですよ。</p>



<figure class="wp-block-image"><img decoding="async" src="https://mashukabu.com/wp-content/uploads/2026/03/03_result_iferror-search.png" alt="03 result iferror search" /></figure>



<h2 class="wp-block-heading"><span id="toc20">エラー（#VALUE!）の原因と対処法</span></h2>



<h3 class="wp-block-heading"><span id="toc21">エラーの原因</span></h3>



<p>SEARCH関数で#VALUE!エラーが出る原因は主に2つです。</p>



<figure class="wp-block-table"><table><thead><tr><th>原因</th><th>例</th><th>説明</th></tr></thead><tbody><tr><td>検索文字列が見つからない</td><td><code>=SEARCH("@", "tanaka")</code></td><td>テキストに@が存在しない</td></tr><tr><td>開始位置がテキスト長を超えている</td><td><code>=SEARCH("a", "abc", 10)</code></td><td>3文字しかないのに10文字目から検索</td></tr></tbody></table></figure>



<p><a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>と違い、大文字小文字の不一致ではエラーになりません。しかし、そもそも検索文字列がテキスト内に存在しないケースは起こり得ます。</p>



<h3 class="wp-block-heading"><span id="toc22">IFERRORで安全に処理する</span></h3>



<p>IFERRORでラップしておけば、エラーの代わりに任意の値を返せます。</p>



<pre class="wp-block-code"><code>=IFERROR(SEARCH(&quot;@&quot;, A2), 0)</code></pre>



<p>@が見つかればその位置を、見つからなければ0を返します。</p>



<p><a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>との組み合わせでも同じパターンが使えます。</p>



<pre class="wp-block-code"><code>=IFERROR(MID(A2, SEARCH(&quot;@&quot;, A2)+1, LEN(A2)), &quot;メールアドレスではありません&quot;)</code></pre>



<p>実務データは書式がバラバラなことも多いです。SEARCH関数を使うときはIFERRORとセットで覚えておくと安心ですよ。</p>



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



<p>SEARCH関数の要点を整理します。</p>



<figure class="wp-block-table"><table><thead><tr><th>ポイント</th><th>内容</th></tr></thead><tbody><tr><td>基本構文</td><td><code>=SEARCH(検索文字列, 対象テキスト, [開始位置])</code></td></tr><tr><td>戻り値</td><td>検索文字列が最初に見つかった位置（1始まり）</td></tr><tr><td>大文字/小文字</td><td>区別しない（FINDは区別する）</td></tr><tr><td>ワイルドカード</td><td><code>*</code>（任意の文字列）<code>?</code>（任意の1文字）が使える</td></tr><tr><td>全角/半角</td><td>区別する（全角「Ａ」と半角「A」は別文字）</td></tr><tr><td>見つからない場合</td><td>#VALUE!エラー（IFERRORで対処）</td></tr><tr><td>開始位置省略</td><td>先頭（1文字目）から検索</td></tr></tbody></table></figure>



<p>SEARCH関数は、大文字小文字を気にせず検索できるのが最大の強みです。英語混じりのデータやユーザー入力のように表記ゆれが多いデータには、<a href="https://mashukabu.com/spreadsheet-find-function/">FIND関数</a>よりSEARCHが向いています。</p>



<p>さらにワイルドカードを使えば、パターンマッチングにも対応できます。まずは「ISNUMBER+SEARCHで含有チェック」というお手軽パターンから試してみてください。慣れてきたらワイルドカード検索や<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>との組み合わせにも挑戦してみましょう。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-search-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのMID関数の使い方｜途中の文字を取り出す方法</title>
		<link>https://mashukabu.com/spreadsheet-mid-function/</link>
					<comments>https://mashukabu.com/spreadsheet-mid-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Wed, 18 Mar 2026 14:38:12 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[LEFT関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[RIGHT関数]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4244</guid>

					<description><![CDATA[スプレッドシートのMID関数で、文字列の途中から指定した文字数を取り出す方法を解説。商品コードや日付の分割など実務例も紹介。LEFT・RIGHTとの使い分けもわかります。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートのMID関数の使い方で悩んでいませんか？商品コードの中間部分だけ、日付の月や日だけを取り出したい場面はよくありますよね。</p>



<p>でも、文字列の途中を手作業で切り出すのは大変です。データ件数が増えるほど、時間もミスも増えていきます。</p>



<p>MID関数を使えばこの作業が一瞬で完了します。この記事では基本構文から実務での活用例、エラー対処法まで丁寧に解説します。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-9" checked><label class="toc-title" for="toc-checkbox-9">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">MID関数とは？スプレッドシートで途中の文字を取り出す基本構文</a><ol><li><a href="#toc2" tabindex="0">書き方（構文）と引数の意味</a></li><li><a href="#toc3" tabindex="0">基本的な使用例</a></li></ol></li><li><a href="#toc4" tabindex="0">実務でよく使うMID関数の活用例</a><ol><li><a href="#toc5" tabindex="0">商品コードの中間部分を取り出す</a></li><li><a href="#toc6" tabindex="0">日付文字列から月や日を取り出す</a></li><li><a href="#toc7" tabindex="0">電話番号の市内局番を取り出す</a></li></ol></li><li><a href="#toc8" tabindex="0">FIND関数と組み合わせて可変長の切り出しをする（応用）</a><ol><li><a href="#toc9" tabindex="0">メールアドレスからドメインを取り出す</a></li><li><a href="#toc10" tabindex="0">2つの区切り文字の間を取り出す</a></li><li><a href="#toc11" tabindex="0">IFERRORでエラーを防ぐ</a></li></ol></li><li><a href="#toc12" tabindex="0">LEFT・RIGHT・MIDの違いと使い分け</a><ol><li><a href="#toc13" tabindex="0">3関数の比較一覧</a></li><li><a href="#toc14" tabindex="0">どれを使うか迷ったときの判断フレーム</a></li></ol></li><li><a href="#toc15" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc16" tabindex="0">開始位置に0やマイナスを指定すると#VALUE!エラー</a></li><li><a href="#toc17" tabindex="0">文字数にマイナスを指定すると#VALUE!エラー</a></li><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">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">MID関数とは？スプレッドシートで途中の文字を取り出す基本構文</span></h2>



<p>MID関数は、セルの文字列を<strong>任意の位置から指定した文字数だけ取り出す</strong>関数です。先頭でも末尾でもなく「途中」から切り出せるのが特徴ですよ。</p>



<p>「MID（ミッド）」は英語の「middle（中間）」が語源です。文字列の中間部分を取り出す動作を表しています。ExcelとGoogleスプレッドシートで完全互換なので、どちらでも使えます。</p>



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



<pre class="wp-block-code"><code>=MID(文字列, 開始位置, 文字数)</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</th></tr></thead><tbody><tr><td>文字列</td><td>必須</td><td>取り出し元のセルまたはテキスト</td></tr><tr><td>開始位置</td><td>必須</td><td>取り出しを始める位置（先頭が1）</td></tr><tr><td>文字数</td><td>必須</td><td>取り出す文字数</td></tr></tbody></table></figure>



<p>LEFT関数やRIGHT関数と違い、3つの引数はすべて必須です。省略するとエラーになるので注意してください。</p>



<p>開始位置は先頭の文字を「1」として数えます。たとえば「ABCDE」の「C」は3文字目なので、開始位置は<code>3</code>です。</p>



<p>全角・半角は関係ありません。どちらも1文字=1文字としてカウントされます。バイト数で計算したい場合はMIDB関数を使いましょう。</p>



<h3 class="wp-block-heading"><span id="toc3">基本的な使用例</span></h3>



<p>セルA1に「東京都新宿区西新宿」と入力されているとします。</p>



<pre class="wp-block-code"><code>=MID(A1, 4, 3)  → 「新宿区」
=MID(A1, 1, 3)  → 「東京都」（先頭からならLEFTでもOK）
=MID(A1, 7, 3)  → 「西新宿」</code></pre>



<p>何文字目から何文字取り出すかを指定するだけです。シンプルですね。</p>



<h2 class="wp-block-heading"><span id="toc4">実務でよく使うMID関数の活用例</span></h2>



<p>MID関数が実際の業務でどう役立つか、よく使うパターンを3つ紹介します。</p>



<h3 class="wp-block-heading"><span id="toc5">商品コードの中間部分を取り出す</span></h3>



<p>「A-1234-BK」のような商品コードで、中央の数字部分だけ取り出したい場面です。</p>



<pre class="wp-block-code"><code>=MID(A2, 3, 4)  → 「1234」</code></pre>



<p>3文字目から4文字を取り出しています。コードの形式が決まっていれば、これだけで完了です。</p>



<p>取り出した数字を計算に使いたい場合はVALUE関数で変換しましょう。MID関数の結果は常に文字列として返ります。</p>



<pre class="wp-block-code"><code>=VALUE(MID(A2, 3, 4))  → 1234（数値）</code></pre>



<h3 class="wp-block-heading"><span id="toc6">日付文字列から月や日を取り出す</span></h3>



<p>「2026-03-18」のような日付文字列から、月や日だけを取り出す例です。</p>



<pre class="wp-block-code"><code>=MID(A2, 6, 2)  → 「03」（月の部分）
=MID(A2, 9, 2)  → 「18」（日の部分）</code></pre>



<p>年はLEFT関数、日はRIGHT関数でも取れます。でも月のように「途中にある文字」はMID関数の出番ですね。</p>



<h3 class="wp-block-heading"><span id="toc7">電話番号の市内局番を取り出す</span></h3>



<p>「03-1234-5678」のような電話番号から市内局番を取り出す例です。</p>



<pre class="wp-block-code"><code>=MID(A2, 4, 4)  → 「1234」</code></pre>



<p>4文字目から4文字を取り出しています。ハイフン位置が固定の場合はシンプルに書けますよ。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>TIP</strong></p><p>ハイフンの位置が固定でない場合は、SUBSTITUTE関数でハイフンを除去してからMIDで取り出すと確実です。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc8">FIND関数と組み合わせて可変長の切り出しをする（応用）</span></h2>



<p>MID関数は開始位置と文字数を固定で指定します。でも「区切り文字の位置がデータによって違う」ケースもありますよね。</p>



<p>そこで便利なのがFIND関数との組み合わせです。FINDは指定した文字が何文字目にあるかを返します。大文字と小文字を区別して検索する関数です。区別が不要な場合はSEARCH関数を使ってください。</p>



<h3 class="wp-block-heading"><span id="toc9">メールアドレスからドメインを取り出す</span></h3>



<p>メールアドレスの<code>@</code>より後ろのドメイン部分を取り出す例です。</p>



<pre class="wp-block-code"><code>=MID(A1, FIND(&quot;@&quot;, A1)+1, LEN(A1))</code></pre>



<p>ちょっとむずかしく見えますが、分解すると簡単です。</p>



<ol class="wp-block-list"><li><code>FIND("@", A1)</code> で <code>@</code> が何文字目かを取得する</li><li>そこに1を足して「@の次の文字位置」を計算する</li><li>文字数にLEN(A1)で全体の長さを指定する</li></ol>



<p>文字数を大きめに指定しても、末尾までの文字が返るだけです。エラーにはなりません。</p>



<p>「tanaka@example.com」なら<code>@</code>は7文字目です。8文字目から残り全部を取り出すので、結果は「example.com」になります。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>NOTE</strong></p><p>LEFT関数を使えば、逆に@より前（ユーザー名）を取り出せます。詳しくは「<a href="https://mashukabu.com/spreadsheet-left-function/">スプレッドシートのLEFT関数の使い方｜左から文字取得</a>」で解説しています。</p></blockquote>



<h3 class="wp-block-heading"><span id="toc10">2つの区切り文字の間を取り出す</span></h3>



<p>「営業部-田中太郎-東京」のようなデータがあるとします。1つ目と2つ目のハイフンの間にある「田中太郎」を取り出してみましょう。</p>



<pre class="wp-block-code"><code>=MID(A1, FIND(&quot;-&quot;,A1)+1, FIND(&quot;-&quot;,A1,FIND(&quot;-&quot;,A1)+1)-FIND(&quot;-&quot;,A1)-1)</code></pre>



<p>数式が長く見えますが、やっていることは3ステップです。</p>



<ol class="wp-block-list"><li>1つ目の<code>-</code>の位置を取得する</li><li>2つ目の<code>-</code>の位置を取得する（第3引数で検索開始位置を指定）</li><li>2つの位置の差から取り出す文字数を計算する</li></ol>



<p>これはMID関数ならではの使い方です。LEFT関数やRIGHT関数では対応できません。</p>



<h3 class="wp-block-heading"><span id="toc11">IFERRORでエラーを防ぐ</span></h3>



<p>対象セルに区切り文字がない場合、FINDはエラーを返します。エラーを防ぐにはIFERRORでラップしましょう。</p>



<pre class="wp-block-code"><code>=IFERROR(MID(A1, FIND(&quot;-&quot;,A1)+1, LEN(A1)), &quot;該当なし&quot;)</code></pre>



<p>区切り文字があれば結果を、なければ「該当なし」を返します。実務データは必ずしもきれいとは限りません。IFERRORパターンは覚えておくと安心ですよ。</p>



<h2 class="wp-block-heading"><span id="toc12">LEFT・RIGHT・MIDの違いと使い分け</span></h2>



<p>文字列を取り出す関数にはMID以外に「LEFT」と「RIGHT」があります。どれも文字列の一部を切り出す関数ですが、取り出す位置が異なります。</p>



<h3 class="wp-block-heading"><span id="toc13">3関数の比較一覧</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>取り出す位置</th><th>構文</th><th>使用例</th></tr></thead><tbody><tr><td>LEFT</td><td>左端（先頭）から</td><td><code>=LEFT(文字列, 文字数)</code></td><td>都道府県名、カテゴリコード</td></tr><tr><td>RIGHT</td><td>右端（末尾）から</td><td><code>=RIGHT(文字列, 文字数)</code></td><td>電話番号末尾4桁、拡張子</td></tr><tr><td>MID</td><td>任意の開始位置から</td><td><code>=MID(文字列, 開始位置, 文字数)</code></td><td>商品コードの中間部分、日付の月</td></tr></tbody></table></figure>



<p>引数の数が違う点に注意してください。LEFTとRIGHTは2引数（文字数は省略可）ですが、MIDは3引数すべて必須です。</p>



<h3 class="wp-block-heading"><span id="toc14">どれを使うか迷ったときの判断フレーム</span></h3>



<p>取り出したい文字がどこにあるかで選べます。</p>



<ul class="wp-block-list"><li><strong>先頭から数えたほうが早い</strong> → <a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a></li><li><strong>末尾から数えたほうが早い</strong> → <a href="https://mashukabu.com/spreadsheet-right-function/">RIGHT関数</a></li><li><strong>真ん中あたりにある</strong> → MID関数</li></ul>



<p>「2026-03-18」から年を取りたいなら先頭4文字なのでLEFTです。日だけなら末尾2文字なのでRIGHTになります。月は途中にあるのでMIDの出番ですね。</p>



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



<p>MID関数で思ったとおりに動かないときのパターンを解説します。</p>



<h3 class="wp-block-heading"><span id="toc16">開始位置に0やマイナスを指定すると#VALUE!エラー</span></h3>



<p>開始位置は1以上の整数を指定する必要があります。0やマイナスの値は受け付けません。</p>



<pre class="wp-block-code"><code>=MID(A1, 0, 3)   → #VALUE!エラー
=MID(A1, -1, 3)  → #VALUE!エラー</code></pre>



<p>LEFT関数は<code>LEFT(A1, 0)</code>で空文字を返します。でもMIDは開始位置に0を指定できません。この違いに注意してください。</p>



<h3 class="wp-block-heading"><span id="toc17">文字数にマイナスを指定すると#VALUE!エラー</span></h3>



<p>文字数もマイナスの値は指定できません。0は指定できますが、空文字列が返ります。</p>



<pre class="wp-block-code"><code>=MID(A1, 2, -1)  → #VALUE!エラー
=MID(A1, 2, 0)   → &quot;&quot;（空文字列）</code></pre>



<h3 class="wp-block-heading"><span id="toc18">開始位置が文字列の長さを超えると空文字列</span></h3>



<p>開始位置が文字列の文字数より大きい場合は空文字列が返ります。エラーにはなりません。</p>



<pre class="wp-block-code"><code>=MID(&quot;Hello&quot;, 10, 3)  → &quot;&quot;（空文字列）</code></pre>



<h3 class="wp-block-heading"><span id="toc19">文字数が残りの文字数を超えても大丈夫</span></h3>



<p>文字数を大きく指定しても、末尾までの文字が返るだけです。エラーにはなりません。</p>



<pre class="wp-block-code"><code>=MID(&quot;Hello&quot;, 3, 100)  → 「llo」</code></pre>



<p>この仕様はFIND関数との組み合わせで活用します。末尾までの正確な文字数がわからなくても、LEN関数で全体の長さを指定すれば確実です。</p>



<h3 class="wp-block-heading"><span id="toc20">結果が文字列になる（数値として使えない）</span></h3>



<p>MID関数の結果は常に文字列型です。数字を取り出しても、そのままでは計算に使えません。</p>



<pre class="wp-block-code"><code>=MID(&quot;A-1234-BK&quot;, 3, 4)      → 「1234」（文字列）
=VALUE(MID(&quot;A-1234-BK&quot;, 3, 4)) → 1234（数値）</code></pre>



<p>合計や比較に使うときはVALUE関数で変換してくださいね。</p>



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



<p>MID関数の要点を整理します。</p>



<figure class="wp-block-table"><table><thead><tr><th>ポイント</th><th>内容</th></tr></thead><tbody><tr><td>基本構文</td><td><code>=MID(文字列, 開始位置, 文字数)</code></td></tr><tr><td>引数</td><td>3つすべて必須（LEFT/RIGHTと異なり省略不可）</td></tr><tr><td>開始位置</td><td>先頭の文字が1（0はエラー）</td></tr><tr><td>文字数超過</td><td>末尾までの文字を返す（エラーにならない）</td></tr><tr><td>開始位置超過</td><td>空文字列を返す（エラーにならない）</td></tr><tr><td>全角・半角</td><td>どちらも1文字としてカウント</td></tr><tr><td>結果の型</td><td>常に文字列（数値にはVALUE関数で変換）</td></tr></tbody></table></figure>



<p>MID関数は文字列操作の三本柱の1つです。まずは「何文字目から何文字取り出す」というシンプルな使い方から試してみてください。</p>



<p>慣れてきたらFIND関数との組み合わせにも挑戦しましょう。区切り文字の位置に応じた柔軟な切り出しができるようになると、実務でのデータ整理の幅が一気に広がりますよ。</p>



<p><a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数（先頭から切り出し）</a>や<a href="https://mashukabu.com/spreadsheet-right-function/">RIGHT関数（末尾から切り出し）</a>と合わせて、文字列操作の三本柱として活用してみてくださいね。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-mid-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>スプレッドシートのFIND関数の使い方｜文字位置を検索する方法</title>
		<link>https://mashukabu.com/spreadsheet-find-function/</link>
					<comments>https://mashukabu.com/spreadsheet-find-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Wed, 18 Mar 2026 14:38:10 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[FIND関数]]></category>
		<category><![CDATA[LEFT関数]]></category>
		<category><![CDATA[MID関数]]></category>
		<category><![CDATA[RIGHT関数]]></category>
		<category><![CDATA[SEARCH関数]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[関数の使い方]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=4242</guid>

					<description><![CDATA[スプレッドシートのFIND関数で、文字列内の特定の文字位置を検索する方法を解説。SEARCHとの違い（大文字小文字区別）やMID・LEFTとの組み合わせ、#VALUE!エラーの対処法もわかります。]]></description>
										<content:encoded><![CDATA[
<p>スプレッドシートで「@マークは何文字目にある？」「スラッシュの位置を調べたい」と思ったことはありませんか？文字列から特定の文字の位置を手作業で数えるのは面倒ですし、データが何百行もあると現実的ではないですよね。</p>



<p>FIND関数を使えば、特定の文字が何文字目にあるかを一発で調べられます。この記事ではスプレッドシートでのFIND関数の基本から、LEFT・MID関数との組み合わせ応用、エラー対処法まで丁寧に解説します。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-10" checked><label class="toc-title" for="toc-checkbox-10">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">FIND関数とは？スプレッドシートで文字の位置を検索する関数</a></li><li><a href="#toc2" tabindex="0">FIND関数の書き方（構文と引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">第3引数（開始位置）の使いどころ</a></li></ol></li><li><a href="#toc5" tabindex="0">基本的な使い方</a></li><li><a href="#toc6" tabindex="0">FIND関数とSEARCH関数の違い</a><ol><li><a href="#toc7" tabindex="0">比較表</a></li><li><a href="#toc8" tabindex="0">どちらを使うか迷ったときの判断基準</a></li></ol></li><li><a href="#toc9" tabindex="0">実務での活用例（LEFT・MID・RIGHTとの組み合わせ）</a><ol><li><a href="#toc10" tabindex="0">メールアドレスの@より前を取り出す（LEFT + FIND）</a></li><li><a href="#toc11" tabindex="0">スラッシュ区切りの日付から年月日を分離する（MID + FIND）</a></li><li><a href="#toc12" tabindex="0">ファイル名から拡張子を取り出す（RIGHT + LEN + FIND）</a></li></ol></li><li><a href="#toc13" tabindex="0">エラー（#VALUE!）の原因と対処法</a><ol><li><a href="#toc14" tabindex="0">エラーの原因</a></li><li><a href="#toc15" tabindex="0">IFERRORで安全に処理する</a></li></ol></li><li><a href="#toc16" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">FIND関数とは？スプレッドシートで文字の位置を検索する関数</span></h2>



<p>FIND関数は、文字列の中から<strong>特定の文字が何文字目にあるかを返す</strong>関数です。読み方は「ファインド」。英語の「Find（見つける）」がそのまま名前になっています。</p>



<p>たとえば「tanaka@example.com」の中で「@」は7文字目にあります。FIND関数はこの「7」という数値を返してくれます。</p>



<p>最大の特徴は<strong>大文字と小文字を区別する</strong>ことです。「A」と「a」を別の文字として扱います。区別しない検索にはSEARCH関数を使います。この違いについては後ほど詳しく解説しますね。</p>



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



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



<pre class="wp-block-code"><code>=FIND(検索文字列, テキスト, [開始位置])</code></pre>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略可</th><th>説明</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>何文字目から検索を始めるか（省略時は1）</td></tr></tbody></table></figure>



<p>戻り値は「検索文字列が最初に見つかった位置」の数値です。1文字目が「1」なので、0始まりではありません。</p>



<h3 class="wp-block-heading"><span id="toc4">第3引数（開始位置）の使いどころ</span></h3>



<p>開始位置を指定すると、途中から検索を開始できます。同じ文字が複数回出てくるテキストで「2番目の出現位置」を調べたいときに使います。</p>



<pre class="wp-block-code"><code>=FIND(&quot;-&quot;, &quot;ABC-001-RED&quot;)      → 4（最初のハイフン）
=FIND(&quot;-&quot;, &quot;ABC-001-RED&quot;, 5)   → 8（2番目のハイフン）</code></pre>



<p>1回目のFINDで最初のハイフン位置（4）を取得し、その次の位置（5）から検索を再開する仕組みです。<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>との組み合わせで区切り文字間の文字を取り出すときに活躍しますよ。</p>



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



<p>セルA2に「tanaka@example.com」が入っているとします。</p>



<pre class="wp-block-code"><code>=FIND(&quot;@&quot;, A2)        → 7（@は7文字目）
=FIND(&quot;example&quot;, A2)  → 8（&quot;example&quot;は8文字目から始まる）
=FIND(&quot;a&quot;, A2)        → 2（最初の小文字&quot;a&quot;は2文字目）</code></pre>



<p>検索文字列は1文字でも複数文字でもOKです。複数文字の場合は先頭文字の位置を返します。</p>



<p>大文字小文字を区別するので、<code>=FIND("T", A2)</code> は「T」が存在しないため#VALUE!エラーになります。先頭は小文字の「t」だからです。</p>



<h2 class="wp-block-heading"><span id="toc6">FIND関数とSEARCH関数の違い</span></h2>



<p>スプレッドシートには文字位置を調べる関数が2つあります。FINDとSEARCHです。用途に合わせて使い分けましょう。</p>



<h3 class="wp-block-heading"><span id="toc7">比較表</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>FIND</th><th>SEARCH</th></tr></thead><tbody><tr><td>大文字/小文字</td><td><strong>区別する</strong></td><td>区別しない</td></tr><tr><td>ワイルドカード</td><td>使えない</td><td><code>*</code>（任意の文字列）<code>?</code>（任意の1文字）が使える</td></tr><tr><td>用途</td><td>完全一致で正確に検索</td><td>あいまい検索・大文字小文字を気にしない場合</td></tr><tr><td>構文</td><td><code>=FIND(検索文字列, テキスト, [開始位置])</code></td><td><code>=SEARCH(検索文字列, テキスト, [開始位置])</code></td></tr></tbody></table></figure>



<h3 class="wp-block-heading"><span id="toc8">どちらを使うか迷ったときの判断基準</span></h3>



<p>使い分けのポイントはシンプルです。</p>



<ul class="wp-block-list"><li><strong>大文字小文字を区別したい</strong> → FIND</li><li><strong>区別しなくてよい</strong> → SEARCH</li><li><strong>ワイルドカードで曖昧検索したい</strong> → SEARCH</li></ul>



<p>実務では「@」「/」「-」のような記号の位置を調べる場面が多いです。記号には大文字小文字がないので、FINDでもSEARCHでも同じ結果になります。どちらを使っても大丈夫ですよ。</p>



<p>一方、「CSV」と「csv」を区別して検索したい場面ではFIND一択です。</p>



<h2 class="wp-block-heading"><span id="toc9">実務での活用例（LEFT・MID・RIGHTとの組み合わせ）</span></h2>



<p>FIND関数の真価は、他の文字列関数と組み合わせたときに発揮されます。FIND関数で「位置」を調べて、<a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a>や<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>で「文字を取り出す」のが定番パターンです。</p>



<h3 class="wp-block-heading"><span id="toc10">メールアドレスの@より前を取り出す（LEFT + FIND）</span></h3>



<p>A2に「tanaka@example.com」が入っています。@より前の「tanaka」を取り出してみましょう。</p>



<pre class="wp-block-code"><code>=LEFT(A2, FIND(&quot;@&quot;, A2)-1)  → 「tanaka」</code></pre>



<p>分解して見ていきます。</p>



<ol class="wp-block-list"><li><code>FIND("@", A2)</code> → @は7文字目</li><li>7 &#8211; 1 = 6（@の直前の位置）</li><li><code>LEFT(A2, 6)</code> → 先頭から6文字で「tanaka」</li></ol>



<p>FINDで位置を調べて、LEFTの文字数に渡すだけです。メールアドレスの長さが人ごとに違っても正しく取り出せますよ。</p>



<h3 class="wp-block-heading"><span id="toc11">スラッシュ区切りの日付から年月日を分離する（MID + FIND）</span></h3>



<p>A2に「2024/03/18」が入っています。年・月・日をそれぞれ取り出してみましょう。</p>



<pre class="wp-block-code"><code>年: =LEFT(A2, FIND(&quot;/&quot;, A2)-1)                → 「2024」
月: =MID(A2, FIND(&quot;/&quot;, A2)+1, FIND(&quot;/&quot;, A2, FIND(&quot;/&quot;, A2)+1)-FIND(&quot;/&quot;, A2)-1)  → 「03」
日: =MID(A2, FIND(&quot;/&quot;, A2, FIND(&quot;/&quot;, A2)+1)+1, LEN(A2))  → 「18」</code></pre>



<p>ちょっとむずかしく見えますが、やっていることはシンプルです。</p>



<ul class="wp-block-list"><li><strong>年</strong>: 最初の「/」より前をLEFTで取得</li><li><strong>月</strong>: 1番目の「/」と2番目の「/」の間をMIDで取得</li><li><strong>日</strong>: 2番目の「/」より後ろをMIDで取得</li></ul>



<p>2番目の「/」を見つけるには、FIND関数の第3引数を使います。<code>FIND("/", A2, FIND("/", A2)+1)</code> で「1番目の/の次の位置から検索」を実行しています。</p>



<h3 class="wp-block-heading"><span id="toc12">ファイル名から拡張子を取り出す（RIGHT + LEN + FIND）</span></h3>



<p>A2に「report.pdf」が入っています。ピリオド以降の「pdf」を取り出す例です。</p>



<pre class="wp-block-code"><code>=RIGHT(A2, LEN(A2)-FIND(&quot;.&quot;, A2))  → 「pdf」</code></pre>



<ol class="wp-block-list"><li><code>FIND(".", A2)</code> → ピリオドは7文字目</li><li><code>LEN(A2)</code> → 全体は10文字</li><li>10 &#8211; 7 = 3</li><li><code>RIGHT(A2, 3)</code> → 末尾3文字で「pdf」</li></ol>



<p><a href="https://mashukabu.com/spreadsheet-right-function/">RIGHT関数</a>とLEN関数（文字列全体の文字数を返す関数）を組み合わせると「特定の文字より後ろ全部」を取得できます。拡張子が「xlsx」のように4文字でも正しく動きますよ。</p>



<h2 class="wp-block-heading"><span id="toc13">エラー（#VALUE!）の原因と対処法</span></h2>



<p>FIND関数で最も多いのが#VALUE!エラーです。原因は大きく2つあります。</p>



<h3 class="wp-block-heading"><span id="toc14">エラーの原因</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>原因</th><th>例</th><th>説明</th></tr></thead><tbody><tr><td>検索文字列が見つからない</td><td><code>=FIND("@", "tanaka")</code></td><td>テキストに@が存在しない</td></tr><tr><td>開始位置がテキスト長を超えている</td><td><code>=FIND("a", "abc", 10)</code></td><td>3文字しかないのに10文字目から検索</td></tr></tbody></table></figure>



<p>大文字小文字を区別するFINDでは、「A」を検索しているのにテキスト内には「a」しかない場合もエラーになります。意図しないエラーの原因になりやすいので注意してください。</p>



<h3 class="wp-block-heading"><span id="toc15">IFERRORで安全に処理する</span></h3>



<p>検索対象が見つからないケースを想定して、IFERRORでラップするのが実務の定番です。</p>



<pre class="wp-block-code"><code>=IFERROR(FIND(&quot;@&quot;, A2), 0)</code></pre>



<p>@が見つかればその位置を、見つからなければ0を返します。</p>



<p>LEFT関数との組み合わせでも同じパターンが使えます。</p>



<pre class="wp-block-code"><code>=IFERROR(LEFT(A2, FIND(&quot;@&quot;, A2)-1), &quot;メールアドレスではありません&quot;)</code></pre>



<p>実務データは書式がバラバラなことも多いです。FIND関数を使うときはIFERRORとセットで覚えておくと安心ですよ。</p>



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



<p>FIND関数の要点を整理します。</p>



<figure class="wp-block-table"><table><thead><tr><th>ポイント</th><th>内容</th></tr></thead><tbody><tr><td>基本構文</td><td><code>=FIND(検索文字列, テキスト, [開始位置])</code></td></tr><tr><td>戻り値</td><td>検索文字列が最初に見つかった位置（1始まり）</td></tr><tr><td>大文字/小文字</td><td>区別する（SEARCHは区別しない）</td></tr><tr><td>ワイルドカード</td><td>使えない（SEARCHは使える）</td></tr><tr><td>見つからない場合</td><td>#VALUE!エラー（IFERRORで対処）</td></tr><tr><td>開始位置省略</td><td>先頭（1文字目）から検索</td></tr></tbody></table></figure>



<p>FIND関数は単体では「位置を調べる」だけの関数です。でも<a href="https://mashukabu.com/spreadsheet-left-function/">LEFT関数</a>・<a href="https://mashukabu.com/spreadsheet-mid-function/">MID関数</a>・<a href="https://mashukabu.com/spreadsheet-right-function/">RIGHT関数</a>と組み合わせると、文字列を自在に分割できる強力なツールになります。</p>



<p>まずは「@の位置を調べる」「/の位置を調べる」というシンプルな使い方から試してみてください。慣れてきたらLEFT+FINDやMID+FINDの組み合わせに挑戦して、文字列操作の幅を広げていきましょう。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-find-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
