<?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>Trim &#8211; biz-tactics</title>
	<atom:link href="https://mashukabu.com/tag/trim/feed/" rel="self" type="application/rss+xml" />
	<link>https://mashukabu.com</link>
	<description></description>
	<lastBuildDate>Wed, 10 Jun 2026 13:07:26 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>

<image>
	<url>https://mashukabu.com/wp-content/uploads/2022/04/cropped-site-icon-32x32.png</url>
	<title>Trim &#8211; biz-tactics</title>
	<link>https://mashukabu.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>VBA WorksheetFunction.Trim の使い方｜VBA Trim との違いと使い分けを解説</title>
		<link>https://mashukabu.com/vba-worksheetfunction-trim/</link>
					<comments>https://mashukabu.com/vba-worksheetfunction-trim/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Mon, 08 Jun 2026 15:50:48 +0000</pubDate>
				<category><![CDATA[VBA・マクロ]]></category>
		<category><![CDATA[Trim]]></category>
		<category><![CDATA[VBA]]></category>
		<category><![CDATA[WorksheetFunction]]></category>
		<category><![CDATA[データクリーニング]]></category>
		<category><![CDATA[マクロ]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[空白除去]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=7849</guid>

					<description><![CDATA[VBA の WorksheetFunction.Trim は、文字列の先頭・末尾だけでなく単語間の連続スペースも1つに圧縮できます。中間スペースを残す VBA 標準の Trim 関数との違いを入力→出力の比較表で解説し、CSV やシステム出力のデータクリーニングに使える実務コードも紹介。Chr(160) ノーブレークスペースが消えない落とし穴と対処法もカバーしました。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">VBA の <code>Trim</code> 関数を使ったのに、文字列の途中にある余分なスペースが消えなくて困ったことはありませんか。実は、VBA の標準 <code>Trim</code> 関数は先頭と末尾のスペースしか削除しません。単語の間にある連続スペースを1つにまとめたいときは、<code>WorksheetFunction.Trim</code> を使います。</p>



<p class="wp-block-paragraph">この記事では、<code>WorksheetFunction.Trim</code> の使い方を、VBA 標準の <code>Trim</code>・<code>LTrim</code>・<code>RTrim</code> との違いとあわせて解説します。4つの空白処理の挙動は、入力と出力の比較表で整理します。CSV やシステム出力のデータクリーニングに使える実務コードも紹介します。最後に、<code>Trim</code> 系をどれだけ使っても消えないノーブレークスペース（Chr(160)）の落とし穴と対処法も取り上げます。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-1" checked><label class="toc-title" for="toc-checkbox-1">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">VBA の WorksheetFunction.Trim とは？</a></li><li><a href="#toc2" tabindex="0">WorksheetFunction.Trim の使い方</a><ol><li><a href="#toc3" tabindex="0">VBE の起動と標準モジュールの準備</a></li><li><a href="#toc4" tabindex="0">基本コード</a></li></ol></li><li><a href="#toc5" tabindex="0">VBA Trim・LTrim・RTrim との違い｜4関数の比較表</a></li><li><a href="#toc6" tabindex="0">WorksheetFunction.Trim が活躍する実務シーン</a><ol><li><a href="#toc7" tabindex="0">実務コード1: 1つのセルをクレンジングする</a></li><li><a href="#toc8" tabindex="0">実務コード2: セル範囲を一括クレンジングする</a></li></ol></li><li><a href="#toc9" tabindex="0">ノーブレークスペース（Chr(160)）が削除できない落とし穴と対処法</a></li><li><a href="#toc10" tabindex="0">WorksheetFunction.Trim を使うときの注意点・よくあるエラー</a></li><li><a href="#toc11" tabindex="0">まとめ</a><ol><li><a href="#toc12" tabindex="0">関連記事</a></li></ol></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">VBA の WorksheetFunction.Trim とは？</span></h2>



<p class="wp-block-paragraph"><code>WorksheetFunction.Trim</code> は、ワークシート関数の TRIM を VBA から呼び出すメソッドです。文字列の先頭と末尾のスペースを削除します。さらに、単語の間にある連続したスペースも1つだけ残して圧縮します。</p>



<p class="wp-block-paragraph">VBA には標準の <code>Trim</code> 関数もあります。ただし標準の <code>Trim</code> 関数は、中間の連続スペースには手を付けません。「単語間のスペースを1つに詰める」処理は、VBA 標準関数にはない機能です。</p>



<p class="wp-block-paragraph">そこで <code>WorksheetFunction</code> オブジェクトを経由して、ワークシート関数の TRIM を借りてくるわけです。具体的な挙動を見てみましょう。</p>



<pre class="wp-block-code"><code>result = WorksheetFunction.Trim(&quot;A   B   C&quot;)
'--- 結果は &quot;A B C&quot;（単語間スペースが1つに圧縮される）---</code></pre>



<p class="wp-block-paragraph">入力 <code>"A   B   C"</code> の単語間には、それぞれ3つのスペースがあります。<code>WorksheetFunction.Trim</code> を通すと、すべて1つにまとめられて <code>"A B C"</code> になります。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p>NOTE: ワークシート関数を VBA から呼ぶ仕組み全般については、<a href="https://mashukabu.com/excel-vba-howto-use-worksheetfunction/">VBAでWorksheetFunctionを使う方法</a>で詳しく解説しています。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc2">WorksheetFunction.Trim の使い方</span></h2>



<p class="wp-block-paragraph">まずは基本の構文と、実際に動かすための準備を確認します。</p>



<pre class="wp-block-code"><code>WorksheetFunction.Trim(Arg1)</code></pre>



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



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/省略</th><th>データ型</th><th>説明</th></tr></thead><tbody><tr><td>Arg1</td><td>必須</td><td>String</td><td>余分なスペースを削除したい文字列</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">戻り値は String 型です。<code>Application.WorksheetFunction.Trim(Arg1)</code> と書いても同じ動作になります。<code>Application.</code> は省略できます。</p>



<h3 class="wp-block-heading"><span id="toc3">VBE の起動と標準モジュールの準備</span></h3>



<p class="wp-block-paragraph">コードを書くには、まず VBE（Visual Basic Editor）を開きます。Excel で <code>Alt + F11</code> キーを押すと VBE が起動します。</p>



<p class="wp-block-paragraph">リボンから開くこともできます。「開発」タブの「Visual Basic」ボタンをクリックする方法です。「開発」タブが表示されていない場合は、次の手順で追加します。</p>



<ol class="wp-block-list"><li>「ファイル」→「オプション」を開きます。</li><li>「リボンのユーザー設定」を選びます。</li><li>右側の一覧で「開発」にチェックを入れます。</li></ol>



<p class="wp-block-paragraph">VBE が開いたら、メニューの「挿入」→「標準モジュール」をクリックします。表示されたコード入力欄に、これから紹介するコードを貼り付けてください。</p>



<h3 class="wp-block-heading"><span id="toc4">基本コード</span></h3>



<p class="wp-block-paragraph">実際に <code>WorksheetFunction.Trim</code> を動かす基本コードです。変換前と変換後をメッセージボックスで見比べられるようにしています。</p>



<pre class="wp-block-code"><code>Sub WorksheetFunctionTrimSample()
    Dim sBefore As String '変換前の文字列
    Dim sAfter As String  '変換後の文字列

    '--- 変換前の文字列を用意 ---
    sBefore = &quot;  Excel   VBA   入門  &quot;

    '--- 連続スペースを1つに圧縮し、先頭末尾も削除 ---
    sAfter = WorksheetFunction.Trim(sBefore)

    '--- 変換前後を確認 ---
    MsgBox &quot;変換前：[&quot; &amp; sBefore &amp; &quot;]&quot; &amp; vbCrLf &amp; _
           &quot;変換後：[&quot; &amp; sAfter &amp; &quot;]&quot;
End Sub</code></pre>



<p class="wp-block-paragraph">このコードを実行すると、変換後は <code>[Excel VBA 入門]</code> と表示されます。先頭と末尾のスペースが消え、単語間の連続スペースも1つに詰まりました。<code>[ ]</code> で囲んでいるのは、両端のスペースが消えたことを目で確認しやすくするためです。</p>



<h2 class="wp-block-heading"><span id="toc5">VBA Trim・LTrim・RTrim との違い｜4関数の比較表</span></h2>



<p class="wp-block-paragraph">ここがこの記事の核心です。VBA には空白を扱う関数が複数あります。それぞれ削除する範囲が異なります。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>先頭のスペース</th><th>末尾のスペース</th><th>中間の連続スペース</th></tr></thead><tbody><tr><td><code>Trim</code></td><td>削除する</td><td>削除する</td><td>残す</td></tr><tr><td><code>LTrim</code></td><td>削除する</td><td>残す</td><td>残す</td></tr><tr><td><code>RTrim</code></td><td>残す</td><td>削除する</td><td>残す</td></tr><tr><td><code>WorksheetFunction.Trim</code></td><td>削除する</td><td>削除する</td><td>1つに圧縮する</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">同じ文字列に4つの関数を通すと、結果は次のように変わります。入力は <code>"  A   B  "</code> とします。先頭に2つ、中間に3つ、末尾に2つのスペースがある文字列です。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>出力結果</th></tr></thead><tbody><tr><td><code>Trim("  A   B  ")</code></td><td><code>"A   B"</code></td></tr><tr><td><code>LTrim("  A   B  ")</code></td><td><code>"A   B  "</code></td></tr><tr><td><code>RTrim("  A   B  ")</code></td><td><code>"  A   B"</code></td></tr><tr><td><code>WorksheetFunction.Trim("  A   B  ")</code></td><td><code>"A B"</code></td></tr></tbody></table></figure>



<p class="wp-block-paragraph"><code>Trim</code>・<code>LTrim</code>・<code>RTrim</code> はいずれも、中間の連続スペースをそのまま残します。中間スペースを1つに詰めるのは <code>WorksheetFunction.Trim</code> だけです。ここが最大の違いです。</p>



<p class="wp-block-paragraph">「先頭と末尾だけ消えればいい」場合は VBA 標準の <code>Trim</code> で十分です。「単語間の余分なスペースも整えたい」場合は <code>WorksheetFunction.Trim</code> を選びます。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p>TIP: 各関数の単体の使い方は、<a href="https://mashukabu.com/excel-vba-howto-use-trim/">VBA Trim関数</a>・<a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">VBA LTrim関数</a>・<a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">VBA RTrim関数</a>の各記事で解説しています。空白処理全体の使い分けは<a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBAで空白を削除する方法まとめ</a>も参考にしてください。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc6">WorksheetFunction.Trim が活躍する実務シーン</span></h2>



<p class="wp-block-paragraph"><code>WorksheetFunction.Trim</code> の出番は、間隔がそろっていないデータを受け取ったときです。代表的なのが、システムから出力されたレポートや CSV ファイルです。項目の区切りが複数スペースになっていることがよくあります。実務で使えるコードを2つ紹介します。</p>



<h3 class="wp-block-heading"><span id="toc7">実務コード1: 1つのセルをクレンジングする</span></h3>



<p class="wp-block-paragraph">A 列のセルに入った文字列を整え、B 列に書き出すコードです。</p>



<pre class="wp-block-code"><code>Sub CleanSingleCell()
    Dim sRaw As String   '元の文字列
    Dim sClean As String '整形後の文字列

    '--- A2セルの値を取得 ---
    sRaw = Range(&quot;A2&quot;).Value

    '--- 先頭末尾＋中間スペースを正規化 ---
    sClean = WorksheetFunction.Trim(sRaw)

    '--- 整形結果をB2セルに出力 ---
    Range(&quot;B2&quot;).Value = sClean
End Sub</code></pre>



<p class="wp-block-paragraph">A2 に <code>"  山田    太郎  "</code> のような値が入っていても、B2 には <code>"山田 太郎"</code> ときれいに出力されます。</p>



<h3 class="wp-block-heading"><span id="toc8">実務コード2: セル範囲を一括クレンジングする</span></h3>



<p class="wp-block-paragraph">実務では1セルだけでなく、列全体を一気に処理したい場面が多いはずです。A 列のデータを最終行まで順番に整えるコードです。</p>



<pre class="wp-block-code"><code>Sub CleanRangeWithTrim()
    Dim lastRow As Long '最終行の行番号
    Dim i As Long       '行カウンター

    '--- A列の最終行を取得 ---
    lastRow = Cells(Rows.Count, 1).End(xlUp).Row

    '--- 2行目から最終行まで繰り返す ---
    For i = 2 To lastRow
        '--- 文字列のセルだけを対象に正規化 ---
        If VarType(Cells(i, 1).Value) = vbString Then
            Cells(i, 1).Value = WorksheetFunction.Trim(Cells(i, 1).Value)
        End If
    Next i

    MsgBox &quot;クレンジングが完了しました。&quot;
End Sub</code></pre>



<p class="wp-block-paragraph"><code>VarType</code> でセルの値が文字列かどうかを確認しています。数値や日付のセルに <code>Trim</code> をかけると、意図しない型変換が起きることがあるためです。文字列のセルだけを対象にすると安全です。</p>



<h2 class="wp-block-heading"><span id="toc9">ノーブレークスペース（Chr(160)）が削除できない落とし穴と対処法</span></h2>



<p class="wp-block-paragraph"><code>WorksheetFunction.Trim</code> には1つ大きな落とし穴があります。それが「ノーブレークスペース」です。Web ページや一部のシステムからコピーしたデータに混ざっていることがあります。</p>



<p class="wp-block-paragraph">ノーブレークスペースは、文字コードの値が160の空白文字です。HTML では <code>&nbsp;</code> として使われます。見た目は普通のスペースとそっくりですが、別の文字です。</p>



<p class="wp-block-paragraph"><code>WorksheetFunction.Trim</code> が削除できるのは、値が32の半角スペース（Chr(32)）だけです。これは公式ドキュメントにも明記されています。VBA 標準の <code>Trim</code>・<code>LTrim</code>・<code>RTrim</code> も同じく、ノーブレークスペースには反応しません。</p>



<pre class="wp-block-code"><code>Sub TrimCannotRemoveNbsp()
    Dim sText As String '元の文字列

    '--- 単語の間にノーブレークスペースを含む文字列 ---
    sText = &quot;A&quot; &amp; Chr(160) &amp; Chr(160) &amp; &quot;B&quot;

    '--- Trimをかけてもノーブレークスペースは残る ---
    MsgBox &quot;[&quot; &amp; WorksheetFunction.Trim(sText) &amp; &quot;]&quot;
End Sub</code></pre>



<p class="wp-block-paragraph">このコードを実行しても、A と B の間のノーブレークスペースは消えません。「Trim を試したのに空白が消えない」という現象の正体は、たいていこれです。</p>



<p class="wp-block-paragraph">対処法は、ノーブレークスペースを先に半角スペースへ変換することです。<code>Replace</code> 関数を使います。半角スペースに変えてから <code>WorksheetFunction.Trim</code> を通すと、区切りのスペースを残しつつ正規化できます。</p>



<pre class="wp-block-code"><code>Sub CleanWithNbsp()
    Dim sRaw As String   '元の文字列
    Dim sClean As String '整形後の文字列

    '--- A2セルの値を取得 ---
    sRaw = Range(&quot;A2&quot;).Value

    '--- ノーブレークスペースを半角スペースに変換 ---
    sClean = Replace(sRaw, Chr(160), &quot; &quot;)

    '--- 連続スペースを1つに圧縮し先頭末尾も削除 ---
    sClean = WorksheetFunction.Trim(sClean)

    '--- 整形結果をB2セルに出力 ---
    Range(&quot;B2&quot;).Value = sClean
End Sub</code></pre>



<p class="wp-block-paragraph">「<code>Chr(160)</code> を半角スペースに変換 → <code>WorksheetFunction.Trim</code>」の順番がポイントです。いきなり全削除すると、本来必要な区切りスペースまで失われることがあります。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p>NOTE: ノーブレークスペースの正体と消し方は、<a href="https://mashukabu.com/about-nbsp/">Excelで消えない空白の正体と消し方</a>でさらに詳しく解説しています。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc10">WorksheetFunction.Trim を使うときの注意点・よくあるエラー</span></h2>



<p class="wp-block-paragraph">最後に、つまずきやすいポイントを整理します。</p>



<p class="wp-block-paragraph">1つ目は、タブや改行は削除されないことです。削除対象はあくまで半角スペースだけです。タブ（Chr(9)）や改行（Chr(10)、Chr(13)）が混じっている場合は、<code>Replace</code> で個別に処理する必要があります。</p>



<p class="wp-block-paragraph">2つ目は、全角スペースの扱いです。<code>WorksheetFunction.Trim</code> は半角スペースを対象に設計されています。全角スペースを確実に消したいときは、<code>Replace(s, "　", " ")</code> で半角に変換してから処理するのが安全です。</p>



<p class="wp-block-paragraph">3つ目は、空セルや数値セルへの適用です。空のセルや数値のセルを直接渡すと、思わぬ型変換が起きることがあります。実務コード2のように <code>VarType</code> で文字列かどうかを確認してから渡すと、トラブルを防げます。</p>



<figure class="wp-block-table"><table><thead><tr><th>つまずきポイント</th><th>原因</th><th>対処法</th></tr></thead><tbody><tr><td>中間スペースが残る</td><td>VBA 標準の <code>Trim</code> を使っている</td><td><code>WorksheetFunction.Trim</code> を使う</td></tr><tr><td>ある空白だけ消えない</td><td>ノーブレークスペース（Chr(160)）</td><td><code>Replace</code> で半角スペースに変換してから処理</td></tr><tr><td>全角スペースが残る</td><td>対象は半角スペースのみ</td><td><code>Replace(s, "　", " ")</code> で半角に変換</td></tr><tr><td>タブ・改行が残る</td><td>対象は半角スペースのみ</td><td><code>Replace</code> で Chr(9)/Chr(10)/Chr(13) を処理</td></tr></tbody></table></figure>



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



<p class="wp-block-paragraph"><code>WorksheetFunction.Trim</code> は、文字列の先頭・末尾のスペースに加えて、単語間の連続スペースも1つに圧縮できるメソッドです。VBA 標準の <code>Trim</code> 関数が中間スペースを残すのに対し、こちらは中間スペースを詰めてくれます。この違いが両者の最大のポイントです。</p>



<p class="wp-block-paragraph">システム出力や CSV インポート後のデータで、間隔が不規則な文字列を整えたいときに役立ちます。ただし、ノーブレークスペース（Chr(160)）は <code>Trim</code> 系では消せません。<code>Replace</code> で半角スペースに変換してから処理する、という流れを覚えておくと安心です。</p>



<p class="wp-block-paragraph">空白処理の関数はそれぞれ役割が違います。先頭・末尾だけなら <code>Trim</code>、片側だけなら <code>LTrim</code>/<code>RTrim</code>、中間も整えるなら <code>WorksheetFunction.Trim</code>、と使い分けてみてください。</p>



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



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-vba-howto-use-trim/">VBA Trim関数の使い方｜前後の空白を一括削除する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">VBA LTrim関数の使い方｜先頭の空白を削除する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">VBA RTrim関数の使い方｜末尾の空白を一括削除する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBAで空白を削除する方法｜Trim・Replace・全角スペースの対処法まとめ</a></li><li><a href="https://mashukabu.com/vba-trim-ltrim-rtrim/">VBAのTrim・LTrim・RTrim関数で文字列の空白を除去する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-use-worksheetfunction/">VBAでWorksheetFunctionを使う方法｜Excel関数をマクロで活用する</a></li><li><a href="https://mashukabu.com/about-nbsp/">Excelで消えない空白の正体と消し方｜ノーブレークスペース完全対策ガイド</a></li></ul>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/vba-worksheetfunction-trim/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>VBAのTrim・LTrim・RTrim関数で文字列の空白を除去する方法｜WorksheetFunction.Trimとの違いも解説</title>
		<link>https://mashukabu.com/vba-trim-ltrim-rtrim/</link>
					<comments>https://mashukabu.com/vba-trim-ltrim-rtrim/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Mon, 08 Jun 2026 15:50:34 +0000</pubDate>
				<category><![CDATA[VBA・マクロ]]></category>
		<category><![CDATA[LTrim]]></category>
		<category><![CDATA[RTrim]]></category>
		<category><![CDATA[Trim]]></category>
		<category><![CDATA[VBA]]></category>
		<category><![CDATA[マクロ]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[空白除去]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=7845</guid>

					<description><![CDATA[VBAのTrim・LTrim・RTrim関数で文字列の空白を除去する方法を、3関数の違いがわかる比較表とコピペできるコードで解説。全角スペースが消えない原因と対処法、WorksheetFunction.TrimとVBA Trimの違いもフローチャートで整理します。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">VBAでセルの空白を取りたいけれど、Trim・LTrim・RTrimのどれを使えばいいのか迷っていませんか？さらに「Trimをかけたのに全角スペースが消えない」と詰まった経験がある方も多いはずです。</p>



<p class="wp-block-paragraph">この記事では、VBAの空白除去でつまずきがちなポイントを <strong>比較表と判断フローチャート</strong> で一気に整理します。3つの関数の違いから、全角スペースが消えない本当の原因、<code>WorksheetFunction.Trim</code>との違いまで、コピペで動くコードつきで解説していきますね。</p>



<p class="wp-block-paragraph">各関数の詳しい使い方は個別の記事にまとめてあるので、本記事は「結局どれを使えばいいの？」を最短で解決する地図として使ってください。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-2" checked><label class="toc-title" for="toc-checkbox-2">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">VBA Trim・LTrim・RTrimの違い【結論】</a><ol><li><a href="#toc2" tabindex="0">3関数の比較表（削除位置・構文・使う場面）</a></li><li><a href="#toc3" tabindex="0">迷ったらどれを使う？1分でわかる選び方</a></li></ol></li><li><a href="#toc4" tabindex="0">VBA Trim関数の基本と使い方</a><ol><li><a href="#toc5" tabindex="0">Trimの構文と基本コード（コピペで動く）</a></li><li><a href="#toc6" tabindex="0">LTrim・RTrimとの動作の違い</a></li></ol></li><li><a href="#toc7" tabindex="0">VBEの起動とコードの準備</a></li><li><a href="#toc8" tabindex="0">Trimで空白が消えないときの原因と対処法</a><ol><li><a href="#toc9" tabindex="0">全角スペースはTrimでは消えない</a></li><li><a href="#toc10" tabindex="0">タブ・改行・NBSPもTrimの対象外</a></li><li><a href="#toc11" tabindex="0">どの空白をどう消す？判断フローチャート</a></li></ol></li><li><a href="#toc12" tabindex="0">WorksheetFunction.TrimとVBA Trimの違い</a><ol><li><a href="#toc13" tabindex="0">中間の連続スペースの扱いが違う</a></li><li><a href="#toc14" tabindex="0">VBAからワークシート版Trimを呼ぶ方法</a></li></ol></li><li><a href="#toc15" tabindex="0">実務で使えるTrim・LTrim・RTrimの活用コード</a><ol><li><a href="#toc16" tabindex="0">コピペデータの先頭空白を一括削除（LTrim）</a></li><li><a href="#toc17" tabindex="0">氏名フィールドの全角スペースを正しく除去する</a></li><li><a href="#toc18" tabindex="0">シート全体の前後空白をまとめてクレンジング（Trim）</a></li></ol></li><li><a href="#toc19" tabindex="0">まとめ｜Trim・LTrim・RTrimの使い分け早見表</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">VBA Trim・LTrim・RTrimの違い【結論】</span></h2>



<p class="wp-block-paragraph">先に結論からお伝えします。VBAのTrim・LTrim・RTrimは、<strong>削除する「位置」だけが違う</strong> 3兄弟です。動作そのものはほぼ同じで、空白を消す場所が「前後」「先頭だけ」「末尾だけ」と分かれているだけなんですね。</p>



<h3 class="wp-block-heading"><span id="toc2">3関数の比較表（削除位置・構文・使う場面）</span></h3>



<p class="wp-block-paragraph">3つの関数を「構文・削除位置・戻り値・使う場面」の4軸で横並びにすると、違いが一目でわかります。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>構文</th><th>削除位置</th><th><code>"  VBA 入門  "</code> の戻り値</th><th>こんなときに使う</th></tr></thead><tbody><tr><td><strong>LTrim</strong></td><td><code>LTrim(文字列)</code></td><td>先頭のみ</td><td><code>"VBA 入門  "</code></td><td>先頭のパディングだけ消したい</td></tr><tr><td><strong>RTrim</strong></td><td><code>RTrim(文字列)</code></td><td>末尾のみ</td><td><code>"  VBA 入門"</code></td><td>末尾の余分な空白だけ消したい</td></tr><tr><td><strong>Trim</strong></td><td><code>Trim(文字列)</code></td><td>先頭＋末尾</td><td><code>"VBA 入門"</code></td><td>前後どちらの空白も不要</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">3つに共通する大事なポイントが2つあります。</p>



<ul class="wp-block-list"><li><strong>中間（文字列の途中）の空白には一切手をつけない</strong>。<code>"VBA 入門"</code> のような単語間のスペースはそのまま残ります。</li><li><strong>削除できるのは半角スペースだけ</strong>。全角スペースは消えません（これが後述する最大の落とし穴です）。</li></ul>



<h3 class="wp-block-heading"><span id="toc3">迷ったらどれを使う？1分でわかる選び方</span></h3>



<p class="wp-block-paragraph">実務で迷ったら、次の3ステップで選べばOKです。</p>



<ol class="wp-block-list"><li><strong>前後どちらも消したい → Trim</strong>。いちばん出番が多いのはこれです。とりあえずTrimを覚えておけば9割の場面に対応できます。</li><li><strong>先頭だけ消したい → LTrim</strong>。固定長データの先頭パディングなど、「末尾の空白は残したい」明確な理由があるときだけ使います。</li><li><strong>末尾だけ消したい → RTrim</strong>。CSVや基幹システム出力で末尾にスペースが付くケースで活躍します。</li></ol>



<p class="wp-block-paragraph">「<code>LTrim</code>と<code>RTrim</code>を両方かけたい」と思ったら、それは<code>Trim</code>を使う場面です。<code>LTrim(RTrim(s))</code>と入れ子にするより、<code>Trim(s)</code>のほうが簡潔でコードの意図も伝わりやすいですよ。</p>



<p class="wp-block-paragraph">それぞれの関数を深掘りしたい方は、<a href="https://mashukabu.com/excel-vba-howto-use-trim/">VBA Trim関数の使い方</a>・<a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim関数の使い方</a>・<a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrim関数の使い方</a>で実践コードつきの解説をしています。</p>



<h2 class="wp-block-heading"><span id="toc4">VBA Trim関数の基本と使い方</span></h2>



<p class="wp-block-paragraph">3関数の代表として、まずはTrimの基本動作を押さえておきましょう。Trimさえ理解すれば、LTrim・RTrimは「位置が違うだけ」なのですぐ応用できます。</p>



<h3 class="wp-block-heading"><span id="toc5">Trimの構文と基本コード（コピペで動く）</span></h3>



<p class="wp-block-paragraph">Trimの構文はとてもシンプルです。</p>



<pre class="wp-block-code"><code>Trim(文字列)</code></pre>



<p class="wp-block-paragraph">引数に文字列を渡すと、前後の半角スペースを取り除いた文字列が返ってきます。まずは動作確認用のコードを試してみましょう。VBE（後述）の標準モジュールに、以下をそのまま貼り付けてF5キーで実行してください。</p>



<pre class="wp-block-code"><code>Sub Trimの動作確認()

    Dim sBefore As String '--- 変換前の文字列 ---
    Dim sAfter As String  '--- 変換後の文字列 ---

    sBefore = &quot;   Excel VBA   &quot;
    sAfter = Trim(sBefore)

    '--- 結果をメッセージボックスで確認 ---
    MsgBox &quot;変換前: [&quot; &amp; sBefore &amp; &quot;]&quot; &amp; vbCrLf &amp; _
           &quot;変換後: [&quot; &amp; sAfter &amp; &quot;]&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">角括弧で囲んでいるので、前後のスペースが消えたことが一目でわかります。前後に空白がない文字列を渡してもエラーにはならず、元の文字列がそのまま返るので、「空白があるか事前にチェックしなきゃ」と心配する必要はありません。</p>



<p class="wp-block-paragraph">なお、正式には<code>Strings.Trim</code>と書きますが、<code>Strings</code>はVBAの標準ライブラリ名なので通常は省略できます。もし複数ライブラリを参照していて「あいまいな名前が検出されました」というエラーが出たら、<code>Strings.Trim</code>とフル修飾で書けば解決しますよ。</p>



<h3 class="wp-block-heading"><span id="toc6">LTrim・RTrimとの動作の違い</span></h3>



<p class="wp-block-paragraph">同じ文字列をLTrim・RTrim・Trimに渡すと、削除される位置の違いがはっきり見えます。</p>



<pre class="wp-block-code"><code>Sub 3関数の違いを比較()

    Dim s As String
    s = &quot;   VBA 入門   &quot;

    Debug.Print &quot;[&quot; &amp; LTrim(s) &amp; &quot;]&quot;  '--- 結果: [VBA 入門   ]（末尾残る） ---
    Debug.Print &quot;[&quot; &amp; RTrim(s) &amp; &quot;]&quot;  '--- 結果: [   VBA 入門]（先頭残る） ---
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;   '--- 結果: [VBA 入門]（前後消える） ---

End Sub</code></pre>



<p class="wp-block-paragraph"><code>Debug.Print</code>の結果はイミディエイトウィンドウに表示されます。3つを並べると、LTrimは左、RTrimは右、Trimは両方を削っているのがよくわかりますね。どの関数も中間の半角スペース（<code>VBA</code>と<code>入門</code>の間）は残したままです。</p>



<h2 class="wp-block-heading"><span id="toc7">VBEの起動とコードの準備</span></h2>



<p class="wp-block-paragraph">ここまでのコードを試すには、VBE（Visual Basic Editor）を開いてコードを書く場所を用意します。すでにVBEに慣れている方は、このセクションは読み飛ばして構いません。</p>



<p class="wp-block-paragraph">Excelを開いた状態で、キーボードの <strong>Alt + F11</strong> を押すとVBEのウィンドウが表示されます。リボンから開く場合は「開発」タブ →「Visual Basic」をクリックしてください。「開発」タブが見当たらないときは、「ファイル」→「オプション」→「リボンのユーザー設定」で「開発」にチェックを入れると表示されます。</p>



<p class="wp-block-paragraph">VBEが開いたら、コードを書く場所（標準モジュール）を追加します。</p>



<ol class="wp-block-list"><li>メニューバーの「挿入」→「標準モジュール」をクリック</li><li>左側のプロジェクトエクスプローラーに「Module1」が追加される</li><li>右側のコードウィンドウにコードを書く</li></ol>



<p class="wp-block-paragraph">VBEの画面構成をもっと詳しく知りたい方は、<a href="https://mashukabu.com/excel-vba-vbe-menu-explanation/">VBEの画面の見方と基本操作</a>も参考にしてみてください。なお、マクロを含むファイルは必ず <strong>マクロ有効ブック（.xlsm）</strong> 形式で保存してくださいね。通常の.xlsx形式で保存するとコードが失われてしまいます。</p>



<h2 class="wp-block-heading"><span id="toc8">Trimで空白が消えないときの原因と対処法</span></h2>



<p class="wp-block-paragraph">「Trimをかけたのに空白が残っている」——これはVBAの空白処理でいちばん多いつまずきです。原因のほとんどは、<strong>Trim系では消せない種類の空白</strong> が混じっていることにあります。</p>



<h3 class="wp-block-heading"><span id="toc9">全角スペースはTrimでは消えない</span></h3>



<p class="wp-block-paragraph">最初に、いちばん大事なファクトをはっきりさせておきます。</p>



<p class="wp-block-paragraph"><strong>VBAのTrim・LTrim・RTrimが削除できるのは、半角スペース（Chr(32)）だけです。全角スペース（ChrW(12288)）は削除されません。</strong></p>



<p class="wp-block-paragraph">一部のサイトや解説では「VBA Trimで全角スペースも消える」と書かれていることがありますが、これは誤りです。実際に試すと、全角スペースはそのまま残ります。</p>



<pre class="wp-block-code"><code>Sub 全角スペースは消えないことを確認()

    Dim s As String
    s = &quot;　東京都　&quot;  '--- 前後は全角スペース ---

    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    '--- 結果: [　東京都　]（全角スペースは残ったまま） ---

End Sub</code></pre>



<p class="wp-block-paragraph">日本語入力の切り替え忘れで先頭に全角スペースが入る、というのは事務作業で本当によく起こります。「Trimしたのに消えない」と感じたら、まずは全角スペースを疑ってください。対処法は後述しますが、<code>Replace</code>関数で個別に消すのが基本です。</p>



<h3 class="wp-block-heading"><span id="toc10">タブ・改行・NBSPもTrimの対象外</span></h3>



<p class="wp-block-paragraph">全角スペース以外にも、Trim系で消えない「空白に見える文字」があります。次の表で整理しておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>文字</th><th>文字コード</th><th>Trim系で消える？</th><th>主な混入経路</th></tr></thead><tbody><tr><td>半角スペース</td><td>Chr(32)</td><td>前後のみ消える</td><td>CSV末尾・手入力</td></tr><tr><td>全角スペース</td><td>ChrW(12288)</td><td>消えない</td><td>日本語入力の切替忘れ</td></tr><tr><td>タブ</td><td>Chr(9)</td><td>消えない</td><td>TSVインポート</td></tr><tr><td>改行（LF / CR）</td><td>Chr(10) / Chr(13)</td><td>消えない</td><td>セル内改行・他システム連携</td></tr><tr><td>NBSP</td><td>Chr(160)</td><td>消えない</td><td>Webページからのコピペ</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">特に厄介なのが <strong>NBSP（ノーブレークスペース）</strong> です。Webページからコピーしたデータに紛れ込みやすく、見た目はただの半角スペースなのにTrimでは消えません。VLOOKUPが完全一致のはずなのに #N/A を返す、という原因不明のトラブルの正体がこれだったりします。NBSPの詳しい対策は<a href="https://mashukabu.com/about-nbsp/">ノーブレークスペース完全対策ガイド</a>で解説しています。</p>



<p class="wp-block-paragraph">「Trimしても消えない空白」の正体を突き止めたいときは、<code>AscW</code>関数で文字コードを調べるのが確実です。</p>



<pre class="wp-block-code"><code>Sub 消えない空白の正体を調べる()

    Dim s As String, i As Long
    s = Range(&quot;A1&quot;).Value  '--- 調べたいセル ---

    For i = 1 To Len(s)
        Debug.Print &quot;位置&quot; &amp; i &amp; &quot;: [&quot; &amp; Mid(s, i, 1) &amp; _
                    &quot;] → AscW=&quot; &amp; AscW(Mid(s, i, 1))
    Next i

End Sub</code></pre>



<p class="wp-block-paragraph">AscWの結果が <strong>32なら半角スペース、160ならNBSP、12288なら全角スペース</strong> です。正体さえわかれば、対応する<code>Replace</code>文を書くだけで解決できます。</p>



<h3 class="wp-block-heading"><span id="toc11">どの空白をどう消す？判断フローチャート</span></h3>



<p class="wp-block-paragraph">空白の種類が整理できたら、あとは「どの関数を使うか」を判断するだけです。次のフローで考えると迷いません。</p>



<ol class="wp-block-list"><li><strong>半角スペースが前後だけ？</strong> → そのまま <strong>Trim（LTrim / RTrim）</strong> でOK。</li><li><strong>半角スペースが文字列の途中で連続している？</strong> → <strong>WorksheetFunction.Trim</strong> で1つに圧縮（次のセクションで解説）。</li><li><strong>全角スペースが混ざっている？</strong> → <strong><code>Replace(s, ChrW(12288), "")</code></strong> で削除。半角に統一したいなら<code>StrConv(s, vbNarrow)</code>で全角→半角変換してからTrim。</li><li><strong>NBSP・タブ・改行が混ざっている？</strong> → <strong><code>Replace</code></strong> でそれぞれの文字コードを指定して削除。</li></ol>



<p class="wp-block-paragraph">つまり、<strong>「半角スペースの前後」だけがTrim系の守備範囲</strong> で、それ以外はすべてReplaceや別の関数の出番、と覚えておけば判断に迷いません。具体的なReplaceの使い方は<a href="https://mashukabu.com/vba-replace-function/">VBA Replace関数の使い方</a>で詳しく解説しています。</p>



<h2 class="wp-block-heading"><span id="toc12">WorksheetFunction.TrimとVBA Trimの違い</span></h2>



<p class="wp-block-paragraph">VBAには、これまで紹介したTrimのほかに <code>WorksheetFunction.Trim</code> という書き方もあります。名前がそっくりなので混同しがちですが、<strong>動作はまったくの別物</strong> です。ここを押さえておくと「Trimしたのに中間の空白が残る」トラブルを避けられます。</p>



<h3 class="wp-block-heading"><span id="toc13">中間の連続スペースの扱いが違う</span></h3>



<p class="wp-block-paragraph">2つの最大の違いは、<strong>文字列の途中にある連続スペースの扱い</strong> です。</p>



<figure class="wp-block-table"><table><thead><tr><th>比較項目</th><th>VBA Trim</th><th>WorksheetFunction.Trim</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>NBSP（Chr(160)）</td><td>削除しない</td><td>削除しない</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">VBA Trimは前後しか触りませんが、WorksheetFunction.Trim（＝ワークシート関数のTRIMと同じ動作）は前後に加えて中間の連続スペースを1つにまとめます。実際に比べてみましょう。</p>



<pre class="wp-block-code"><code>Sub 中間スペースの扱いを比較()

    Dim s As String
    s = &quot;田中  太郎  &quot;  '--- 中間に半角スペース2つ ---

    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    '--- VBA Trim → [田中  太郎]（中間は2つのまま残る） ---

    Debug.Print &quot;[&quot; &amp; Application.WorksheetFunction.Trim(s) &amp; &quot;]&quot;
    '--- ワークシート版 → [田中 太郎]（中間が1つに圧縮される） ---

End Sub</code></pre>



<p class="wp-block-paragraph">「氏名の途中に余分なスペースが入ってしまったデータを、見栄えよく整えたい」——そんなときはWorksheetFunction.Trimの出番です。逆に「前後だけ確実に消したい」場面ではVBA Trimで十分。中間まで勝手に圧縮されないぶん、データを意図せず変えてしまう心配がありません。</p>



<p class="wp-block-paragraph">なお、どちらも <strong>全角スペースは消せない</strong> 点は共通です。ワークシート関数版だからといって全角に対応するわけではないので注意してください。</p>



<h3 class="wp-block-heading"><span id="toc14">VBAからワークシート版Trimを呼ぶ方法</span></h3>



<p class="wp-block-paragraph">VBAのコード内からワークシート版のTrimを使いたいときは、次のように書きます。</p>



<pre class="wp-block-code"><code>Application.WorksheetFunction.Trim(対象文字列)</code></pre>



<p class="wp-block-paragraph"><code>Application.</code>は省略して<code>WorksheetFunction.Trim(s)</code>と書いても動きます。VBA Trimとの使い分けは、</p>



<ul class="wp-block-list"><li><strong>前後だけ消せば十分</strong> → <code>Trim(s)</code>（VBA版）</li><li><strong>中間の連続スペースも1つにまとめたい</strong> → <code>WorksheetFunction.Trim(s)</code>（ワークシート版）</li></ul>



<p class="wp-block-paragraph">と覚えておくと迷いません。ワークシート上の数式としてのTRIM関数について詳しくは、<a href="https://mashukabu.com/excel-function-howto-use-trim/">ExcelのTRIM関数の使い方</a>で解説しています。</p>



<h2 class="wp-block-heading"><span id="toc15">実務で使えるTrim・LTrim・RTrimの活用コード</span></h2>



<p class="wp-block-paragraph">ここからは、3関数の使い分けを実感できる実務コードを3つ紹介します。いずれもVarType判定で文字列セルだけを処理しているので、数値や日付のセルが混ざっていても安全に動きます。</p>



<h3 class="wp-block-heading"><span id="toc16">コピペデータの先頭空白を一括削除（LTrim）</span></h3>



<p class="wp-block-paragraph">他システムや固定長データからコピーしたデータは、桁を揃えるために先頭にスペースが詰められていることがあります。「末尾の空白は意味があるので残したいが、先頭のパディングだけ消したい」——そんなときはLTrimの出番です。</p>



<pre class="wp-block-code"><code>Sub A列の先頭空白を一括削除()

    Dim ws As Worksheet '--- 対象シート ---
    Dim cell As Range   '--- ループ用セル ---

    Set ws = ActiveSheet

    '--- A列の各セルから先頭の半角スペースを削除 ---
    For Each cell In ws.Range(&quot;A1:A&quot; &amp; ws.Cells(ws.Rows.Count, 1).End(xlUp).Row)
        If VarType(cell.Value) = vbString Then
            cell.Value = LTrim(cell.Value)
        End If
    Next cell

    MsgBox &quot;A列の先頭空白を削除しました。&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">ここでTrimではなくLTrimを選ぶのがポイントです。前後まとめて消したいならTrimですが、「先頭だけ」という明確な意図があるならLTrimのほうがコードの意図が伝わります。<code>For Each</code>の基本は<a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim関数の使い方</a>でも触れています。</p>



<h3 class="wp-block-heading"><span id="toc17">氏名フィールドの全角スペースを正しく除去する</span></h3>



<p class="wp-block-paragraph">事務作業で頻発するのが、氏名の前後に全角スペースが入ってしまうケースです。前述のとおりTrimでは全角スペースを消せないので、<code>Replace</code>で全角スペースを消してからTrimで半角スペースを仕上げる、という二段構えが定番になります。</p>



<pre class="wp-block-code"><code>Sub 氏名の全角スペースを正しく除去()

    Dim ws As Worksheet '--- 対象シート ---
    Dim cell As Range   '--- ループ用セル ---
    Dim sVal As String  '--- セルの値 ---

    Set ws = ActiveSheet

    For Each cell In ws.UsedRange
        If VarType(cell.Value) = vbString Then
            sVal = cell.Value

            '--- Step1: 全角スペースを削除（Trimでは消せない） ---
            sVal = Replace(sVal, ChrW(12288), &quot;&quot;)

            '--- Step2: 残った前後の半角スペースを削除 ---
            sVal = Trim(sVal)

            cell.Value = sVal
        End If
    Next cell

    MsgBox &quot;氏名フィールドの空白を除去しました。&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">処理の順番が大切です。先に<code>Replace</code>で全角スペースを消し、最後に<code>Trim</code>で半角スペースを仕上げます。「Trimだけで済ませようとして全角が残る」という典型的な失敗を、この二段構えで確実に防げます。</p>



<h3 class="wp-block-heading"><span id="toc18">シート全体の前後空白をまとめてクレンジング（Trim）</span></h3>



<p class="wp-block-paragraph">「どの列に空白が混じっているか分からない」というときは、UsedRange全体を走査して前後空白をまとめて削除するのがいちばん手軽です。前後どちらも対象なのでTrimを使います。</p>



<pre class="wp-block-code"><code>Sub シート全体の前後空白をクレンジング()

    Dim ws As Worksheet '--- 対象シート ---
    Dim cell As Range   '--- ループ用セル ---
    Dim lCount As Long  '--- 処理件数カウンタ ---

    Set ws = ActiveSheet

    For Each cell In ws.UsedRange
        '--- 文字列セルかつ数式でないセルだけを処理 ---
        If VarType(cell.Value) = vbString And Not cell.HasFormula Then
            cell.Value = Trim(cell.Value)
            lCount = lCount + 1
        End If
    Next cell

    MsgBox lCount &amp; &quot; 件のセルから前後の空白を削除しました。&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">ポイントは<code>And Not cell.HasFormula</code>の一文です。VLOOKUPやTEXT関数など結果が文字列になる数式セルも<code>VarType</code>ではvbStringを返すため、これを入れておかないと数式を計算結果の文字列で上書きしてしまう恐れがあります。計算式と手入力データが混在する業務ファイルでは、この一行が事故防止に効いてきますよ。空白処理の全体像は<a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBAで空白を削除する方法まとめ</a>で一覧できます。</p>



<h2 class="wp-block-heading"><span id="toc19">まとめ｜Trim・LTrim・RTrimの使い分け早見表</span></h2>



<p class="wp-block-paragraph">最後に、VBAの空白除去の使い分けを早見表でおさらいしましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>やりたいこと</th><th>使う関数・方法</th></tr></thead><tbody><tr><td>前後の半角スペースを消す</td><td><strong>Trim</strong></td></tr><tr><td>先頭の半角スペースだけ消す</td><td><strong>LTrim</strong></td></tr><tr><td>末尾の半角スペースだけ消す</td><td><strong>RTrim</strong></td></tr><tr><td>中間の連続スペースを1つに圧縮</td><td><strong>WorksheetFunction.Trim</strong></td></tr><tr><td>全角スペースを消す</td><td><strong>Replace(s, ChrW(12288), &#8220;&#8221;)</strong></td></tr><tr><td>NBSP・タブ・改行を消す</td><td><strong>Replace</strong> で各文字コードを指定</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">押さえるべきポイントは次の3つです。</p>



<ul class="wp-block-list"><li><strong>Trim・LTrim・RTrimの違いは「削除する位置」だけ</strong>。迷ったらTrimでOK。</li><li><strong>3関数が消せるのは半角スペースだけ</strong>。全角スペースやNBSPは消えないので、<code>Replace</code>を併用する。</li><li><strong>中間の連続スペースを整えたいときはWorksheetFunction.Trim</strong>。VBA Trimは前後しか触らない。</li></ul>



<p class="wp-block-paragraph">空白の処理は地味ですが、VLOOKUPの照合ミスや集計ズレを防ぐ大切な前処理です。本記事の比較表とフローチャートを手元の地図にして、クリーンなデータを手に入れてくださいね。各関数の実践コードをもっと見たい方は、<a href="https://mashukabu.com/excel-vba-howto-use-trim/">VBA Trim関数の使い方</a>・<a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim関数の使い方</a>・<a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrim関数の使い方</a>もあわせてどうぞ。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/vba-trim-ltrim-rtrim/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>【VBA】Trim関数の使い方｜前後の空白を一括削除する方法</title>
		<link>https://mashukabu.com/excel-vba-howto-use-trim/</link>
					<comments>https://mashukabu.com/excel-vba-howto-use-trim/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Fri, 04 Mar 2022 12:19:48 +0000</pubDate>
				<category><![CDATA[VBA・マクロ]]></category>
		<category><![CDATA[Trim]]></category>
		<category><![CDATA[VBA]]></category>
		<category><![CDATA[データクレンジング]]></category>
		<category><![CDATA[マクロ]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[空白削除]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=1290</guid>

					<description><![CDATA[VBAのTrim関数で文字列の前後にある半角スペースを削除する方法を解説。削除できるのは半角のみで全角スペースはReplaceで対処します。UsedRangeでのシート一括削除、VLOOKUP前のデータ整形まで、コピペで動くコードを紹介します。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">VLOOKUPの検索キーは合っているのに「一致するデータなし」になる――そんな経験はありませんか？原因の多くは、文字列の前後に紛れ込んだ見えない空白です。</p>



<p class="wp-block-paragraph">手入力のばらつきやシステム出力のデータには、前後に半角・全角スペースが混じりやすいもの。見た目だけでは判断できないのが厄介ですよね。</p>



<p class="wp-block-paragraph">VBAの <strong>Trim関数</strong> を使えば、文字列の前後にある空白をまとめて一括削除できます。この記事では、VBA Trimの基本構文から業務で使える実践コードまで紹介します。</p>



<p class="wp-block-paragraph">空白削除の全体像を先に把握したい方は、<a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBA空白削除まとめ｜Trim・LTrim・RTrim・Replaceの使い分け方</a>をご覧ください。</p>




  <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">VBA Trim関数とは？前後の空白を削除する関数</a><ol><li><a href="#toc2" tabindex="0">LTrim・RTrim・Trimの違い</a></li><li><a href="#toc3" tabindex="0">ワークシート関数TRIMとの違い</a></li><li><a href="#toc4" tabindex="0">削除できない空白に注意</a></li></ol></li><li><a href="#toc5" tabindex="0">VBEの起動とコードの書き方</a><ol><li><a href="#toc6" tabindex="0">VBE（Visual Basic Editor）の開き方</a></li><li><a href="#toc7" tabindex="0">標準モジュールの挿入</a></li></ol></li><li><a href="#toc8" tabindex="0">VBA Trimの基本コード（コピペで動く）</a></li><li><a href="#toc9" tabindex="0">Trim関数の仕組みを深掘りする</a><ol><li><a href="#toc10" tabindex="0">Strings.TrimとTrimの違い</a></li><li><a href="#toc11" tabindex="0">空白がない場合の挙動</a></li><li><a href="#toc12" tabindex="0">対応する空白の種類</a></li></ol></li><li><a href="#toc13" tabindex="0">VBA Trimの実践コード3選</a><ol><li><a href="#toc14" tabindex="0">シート全体の前後空白を一括削除する</a></li><li><a href="#toc15" tabindex="0">VLOOKUP前にデータを整形する</a></li><li><a href="#toc16" tabindex="0">Trim + Replaceで見えない空白も一掃する</a></li></ol></li><li><a href="#toc17" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc18" tabindex="0">型の不一致（実行時エラー 13）</a></li><li><a href="#toc19" tabindex="0">あいまいな名前のコンパイルエラー</a></li><li><a href="#toc20" tabindex="0">マクロ無効・.xlsm保存の注意</a></li></ol></li><li><a href="#toc21" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">VBA Trim関数とは？前後の空白を削除する関数</span></h2>



<p class="wp-block-paragraph">VBAのTrim関数は、文字列の <strong>先頭と末尾</strong> にある空白を削除して返す関数です。</p>



<p class="wp-block-paragraph">たとえば、こんなふうに変換されます。</p>



<figure class="wp-block-table"><table><thead><tr><th>Before</th><th>After</th></tr></thead><tbody><tr><td><code>"   Excel   "</code></td><td><code>"Excel"</code></td></tr><tr><td><code>"  VBA 入門  "</code></td><td><code>"VBA 入門"</code></td></tr><tr><td><code>"データ"</code></td><td><code>"データ"</code>（変化なし）</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">ポイントは、<strong>前後の空白だけが消える</strong> ということ。文字列の途中にある空白はそのまま残ります。</p>



<h3 class="wp-block-heading"><span id="toc2">LTrim・RTrim・Trimの違い</span></h3>



<p class="wp-block-paragraph">VBAには空白を削除する関数が3つあります。違いをまとめると次のとおりです。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>削除する位置</th><th>用途</th></tr></thead><tbody><tr><td><strong><a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim</a></strong></td><td>先頭のみ</td><td>先頭空白だけ除去したいとき</td></tr><tr><td><strong><a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrim</a></strong></td><td>末尾のみ</td><td>末尾空白だけ除去したいとき</td></tr><tr><td><strong>Trim</strong></td><td>前後両方</td><td>前後どちらの空白も不要なとき</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">迷ったらTrimを選んでおけば間違いありません。前後どちらかだけ除去したい場面では、LTrimやRTrimを使い分けてみてください。</p>



<h3 class="wp-block-heading"><span id="toc3">ワークシート関数TRIMとの違い</span></h3>



<p class="wp-block-paragraph">ExcelのワークシートTRIM関数（セルの数式で使うほう）と、VBAのTrim関数は名前が同じでも動きが異なります。</p>



<figure class="wp-block-table"><table><thead><tr><th>項目</th><th>VBA Trim</th><th>ワークシートTRIM</th></tr></thead><tbody><tr><td>前後の空白削除</td><td>する</td><td>する</td></tr><tr><td>文字列内部の連続スペース</td><td><strong>そのまま残る</strong></td><td><strong>1つに圧縮</strong></td></tr></tbody></table></figure>



<p class="wp-block-paragraph">ワークシート版は内部の連続スペースも整理してくれます。VBAからワークシート版を呼びたい場合は、次のように書きます。</p>



<pre class="wp-block-code"><code>Application.WorksheetFunction.Trim(s)</code></pre>



<p class="wp-block-paragraph">通常の前後空白削除だけならVBA Trimで十分ですよ。「Trimしたのに内部のスペースが残っている」と感じたら、この違いを思い出してみてください。</p>



<p class="wp-block-paragraph">ワークシート版の詳しい使い方は <a href="https://mashukabu.com/excel-function-howto-use-trim/">ExcelのTRIM関数の使い方</a> で解説しています。</p>



<h3 class="wp-block-heading"><span id="toc4">削除できない空白に注意</span></h3>



<p class="wp-block-paragraph">Trimが削除できるのは、<strong>半角スペース（Chr(32)）だけ</strong> です。</p>



<p class="wp-block-paragraph">以下の文字は空白のように見えても <strong>Trimでは削除されません</strong>。</p>



<ul class="wp-block-list"><li>全角スペース（ChrW(12288)）</li><li>タブ文字（Chr(9)）</li><li>改行（Chr(10) / Chr(13)）</li><li><a href="https://mashukabu.com/about-nbsp/">ノーブレークスペース（NBSP）</a>（Chr(160)）</li></ul>



<p class="wp-block-paragraph">日本語のデータで特に注意したいのが全角スペースです。氏名の「姓　名」のような全角区切りはTrimでは消えません。また、Webページからコピーしたデータには、NBSPが含まれていることがあります。Trimで消えない空白に出くわしたら、<code>Replace</code> 関数で個別に対処しましょう。</p>



<pre class="wp-block-code"><code>Replace(対象文字列, ChrW(12288), &quot;&quot;)  '--- 全角スペースを削除 ---
Replace(対象文字列, Chr(160), &quot;&quot;)     '--- NBSPを削除 ---</code></pre>



<p class="wp-block-paragraph">後述の実践コード3つ目で、Replace併用の一括処理コードを紹介しています。</p>



<h2 class="wp-block-heading"><span id="toc5">VBEの起動とコードの書き方</span></h2>



<p class="wp-block-paragraph">VBAのコードを動かすには、まずVBE（Visual Basic Editor）を開いて、コードを書く場所を用意します。</p>



<h3 class="wp-block-heading"><span id="toc6">VBE（Visual Basic Editor）の開き方</span></h3>



<p class="wp-block-paragraph">Excelを開いた状態で、キーボードの <strong>Alt + F11</strong> を押してください。VBEのウィンドウが表示されます。</p>



<p class="wp-block-paragraph">リボンから開く場合は、「開発」タブ →「Visual Basic」をクリックします。「開発」タブが見当たらないときは、「ファイル」→「オプション」→「リボンのユーザー設定」で「開発」にチェックを入れれば表示されますよ。</p>



<p class="wp-block-paragraph">VBEの画面構成について詳しく知りたい方は、<a href="https://mashukabu.com/excel-vba-vbe-menu-explanation/">VBE画面の見方</a> も参考にしてみてください。</p>



<h3 class="wp-block-heading"><span id="toc7">標準モジュールの挿入</span></h3>



<p class="wp-block-paragraph">VBEが開いたら、コードを書く場所（標準モジュール）を追加します。</p>



<ol class="wp-block-list"><li>メニューバーの「挿入」→「標準モジュール」をクリック</li><li>左側のプロジェクトエクスプローラーに「Module1」が追加される</li><li>右側に表示されるコードウィンドウに、コードを書いていく</li></ol>



<p class="wp-block-paragraph">ここまで準備できたら、さっそくTrimを使ってみましょう。</p>



<h2 class="wp-block-heading"><span id="toc8">VBA Trimの基本コード（コピペで動く）</span></h2>



<p class="wp-block-paragraph">Trimの構文はとてもシンプルです。</p>



<pre class="wp-block-code"><code>Strings.Trim(string)</code></pre>



<p class="wp-block-paragraph">引数に文字列を渡すと、前後の空白を取り除いた文字列が返ってきます。</p>



<p class="wp-block-paragraph">まずは動作確認用のコードを試してみましょう。Module1のコードウィンドウに、以下をそのまま貼り付けてください。</p>



<pre class="wp-block-code"><code>Sub Trimの動作確認()

    Dim sBefore As String '--- 変換前の文字列 ---
    Dim sAfter As String  '--- 変換後の文字列 ---

    sBefore = &quot;   Excel VBA   &quot;
    sAfter = Trim(sBefore)

    '--- 結果をメッセージボックスで確認 ---
    MsgBox &quot;変換前: [&quot; &amp; sBefore &amp; &quot;]&quot; &amp; vbCrLf &amp; _
           &quot;変換後: [&quot; &amp; sAfter &amp; &quot;]&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">コードを貼り付けたら、<strong>F5キー</strong> を押して実行してみてください。メッセージボックスに変換前と変換後の文字列が表示されます。角括弧で囲んでいるので、前後のスペースが消えたことが一目でわかるはずです。</p>



<h2 class="wp-block-heading"><span id="toc9">Trim関数の仕組みを深掘りする</span></h2>



<p class="wp-block-paragraph">基本コードが動いたところで、Trimのポイントをもう少し掘り下げておきましょう。</p>



<h3 class="wp-block-heading"><span id="toc10">Strings.TrimとTrimの違い</span></h3>



<p class="wp-block-paragraph">先ほどの構文で <code>Strings.Trim</code> と書きましたが、サンプルコードでは <code>Trim</code> だけで動いていましたよね。</p>



<p class="wp-block-paragraph">実はこの2つは同じ関数です。<code>Strings</code> はVBAの標準ライブラリ名で、通常は省略できます。ただし、複数のライブラリを参照設定している場合は注意が必要です。同じ名前の関数が存在すると名前の衝突が起きて、コンパイルエラーになることがあります。</p>



<p class="wp-block-paragraph">普段は <code>Trim</code> だけで問題ありませんが、エラーが出た場合は <code>Strings.Trim</code> とフル修飾で書くと解決しますよ。</p>



<h3 class="wp-block-heading"><span id="toc11">空白がない場合の挙動</span></h3>



<p class="wp-block-paragraph">前後に空白がない文字列をTrimに渡しても、エラーにはなりません。元の文字列がそのまま返ってきます。</p>



<pre class="wp-block-code"><code>Debug.Print Trim(&quot;Excel&quot;) '--- 結果: &quot;Excel&quot;（変化なし） ---</code></pre>



<p class="wp-block-paragraph">「空白があるかどうか事前にチェックしなきゃ」と心配する必要はないので、安心してまとめて処理できますよ。</p>



<p class="wp-block-paragraph">なお、Nullを渡した場合はNullがそのまま返ります。空文字列を渡した場合は空文字列が返ります。どちらもエラーにはなりません。</p>



<h3 class="wp-block-heading"><span id="toc12">対応する空白の種類</span></h3>



<p class="wp-block-paragraph">あらためて整理しておきます。</p>



<figure class="wp-block-table"><table><thead><tr><th>文字</th><th>コード</th><th>Trimで削除</th></tr></thead><tbody><tr><td>半角スペース</td><td>Chr(32)</td><td>される</td></tr><tr><td>全角スペース</td><td>ChrW(12288)</td><td>されない</td></tr><tr><td>タブ</td><td>Chr(9)</td><td>されない</td></tr><tr><td>改行（LF）</td><td>Chr(10)</td><td>されない</td></tr><tr><td>改行（CR）</td><td>Chr(13)</td><td>されない</td></tr><tr><td>NBSP</td><td>Chr(160)</td><td>されない</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">削除されない空白を含むデータを扱う場合は、<code>Replace</code> 関数を併用するのがおすすめです。</p>



<h2 class="wp-block-heading"><span id="toc13">VBA Trimの実践コード3選</span></h2>



<p class="wp-block-paragraph">ここからは、実際の業務で使えるコードを3つ紹介します。</p>



<h3 class="wp-block-heading"><span id="toc14">シート全体の前後空白を一括削除する</span></h3>



<p class="wp-block-paragraph">実際の業務データでは、空白が混じる列は1つとは限りません。次のコードは、UsedRange全体を走査して、文字列が入っているセルの前後空白をまとめて削除します。</p>



<pre class="wp-block-code"><code>Sub シート全体の前後空白を一括削除()

    Dim ws As Worksheet   '--- 対象シート ---
    Dim rng As Range      '--- データ範囲 ---
    Dim cell As Range     '--- ループ用セル ---
    Dim lCount As Long    '--- 処理件数カウンタ ---

    Set ws = ActiveSheet
    Set rng = ws.UsedRange

    '--- 各セルの前後空白を削除 ---
    For Each cell In rng
        If VarType(cell.Value) = vbString Then
            cell.Value = Trim(cell.Value)
            lCount = lCount + 1
        End If
    Next cell

    MsgBox lCount &amp; &quot; 件のセルから前後の空白を削除しました。&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph"><code>VarType(cell.Value) = vbString</code> で文字列セルだけを対象にしているのがポイントです。数値や日付のセルをそのままTrimに渡すと型の不一致が起きる場合があるので、この判定を入れておくと安全ですよ。</p>



<p class="wp-block-paragraph"><a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim</a>や<a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrim</a>のA列限定コードとは違い、「どの列に空白があるか分からない」ときに便利です。</p>



<h3 class="wp-block-heading"><span id="toc15">VLOOKUP前にデータを整形する</span></h3>



<p class="wp-block-paragraph">VLOOKUPの検索がうまくいかない原因の多くは、キー列の空白です。次のコードは、検索キーが入っているA列をTrimで整形してから、VLOOKUPを実行します。</p>



<pre class="wp-block-code"><code>Sub Trim整形してからVLOOKUP()

    Dim ws As Worksheet    '--- 対象シート ---
    Dim lastRow As Long    '--- 最終行 ---
    Dim i As Long          '--- ループカウンタ ---
    Dim sKey As String     '--- 検索キー ---
    Dim vResult As Variant '--- 検索結果 ---

    Set ws = ActiveSheet
    lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row

    '--- A列の前後空白を除去 ---
    For i = 2 To lastRow
        If VarType(ws.Cells(i, &quot;A&quot;).Value) = vbString Then
            ws.Cells(i, &quot;A&quot;).Value = Trim(ws.Cells(i, &quot;A&quot;).Value)
        End If
    Next i

    '--- VLOOKUPでSheet2のマスタから値を取得 ---
    For i = 2 To lastRow
        sKey = ws.Cells(i, &quot;A&quot;).Value
        vResult = Application.VLookup( _
            sKey, Sheets(&quot;Sheet2&quot;).Range(&quot;A:B&quot;), 2, False)

        If IsError(vResult) Then
            ws.Cells(i, &quot;B&quot;).Value = &quot;該当なし&quot;
        Else
            ws.Cells(i, &quot;B&quot;).Value = vResult
        End If
    Next i

    MsgBox &quot;VLOOKUP完了&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">先にTrimで整形するひと手間を入れるだけで、「データはあるのに一致しない」というトラブルを防げます。照合先のマスタ側にも空白がある場合は、マスタのA列にも同じTrim処理をかけてくださいね。</p>



<h3 class="wp-block-heading"><span id="toc16">Trim + Replaceで見えない空白も一掃する</span></h3>



<p class="wp-block-paragraph">Trimだけでは取り切れないタブやNBSPもまとめて除去したい場面があります。次のコードは、Trimに加えてReplaceで非対応の空白文字も一掃します。</p>



<pre class="wp-block-code"><code>Sub 見えない空白もまとめて一掃()

    Dim ws As Worksheet   '--- 対象シート ---
    Dim cell As Range     '--- ループ用セル ---
    Dim sVal As String    '--- セルの値 ---
    Dim lCount As Long    '--- 処理件数カウンタ ---

    Set ws = ActiveSheet

    For Each cell In ws.UsedRange
        If VarType(cell.Value) = vbString Then
            sVal = cell.Value

            '--- Step1: 前後の半角スペースを削除 ---
            sVal = Trim(sVal)

            '--- Step2: 全角スペースを削除 ---
            sVal = Replace(sVal, ChrW(12288), &quot;&quot;)

            '--- Step3: タブ文字を削除 ---
            sVal = Replace(sVal, Chr(9), &quot;&quot;)

            '--- Step4: NBSP（ノーブレークスペース）を削除 ---
            sVal = Replace(sVal, Chr(160), &quot;&quot;)

            '--- Step5: 改行を削除（必要に応じて） ---
            sVal = Replace(sVal, vbCr, &quot;&quot;)
            sVal = Replace(sVal, vbLf, &quot;&quot;)

            If cell.Value &lt;&gt; sVal Then
                cell.Value = sVal
                lCount = lCount + 1
            End If
        End If
    Next cell

    MsgBox lCount &amp; &quot; 件のセルから空白・制御文字を削除しました。&quot;, vbInformation

End Sub</code></pre>



<p class="wp-block-paragraph">Webページからコピーしたデータや、外部システムから出力したCSVには、全角スペースやタブ・NBSPが混じっていることが多いです。このコードなら、Trimで消せない空白もまとめて対処できますよ。なお、Step2のReplaceは文字列の途中にある全角スペースも削除します。「姓　名」のような内部の全角区切りを残したい場合は、Step2を外して使ってください。</p>



<p class="wp-block-paragraph">空白の種類別の対処法をもっと詳しく知りたい方は、<a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBA空白削除まとめ｜Trim・LTrim・RTrim・Replaceの使い分け方</a>もあわせてどうぞ。</p>



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



<p class="wp-block-paragraph">Trim自体はシンプルな関数ですが、周辺で引っかかりやすいポイントがあります。</p>



<h3 class="wp-block-heading"><span id="toc18">型の不一致（実行時エラー 13）</span></h3>



<p class="wp-block-paragraph">数値が入っているセルの値を、String型の変数に直接代入しようとすると「型の不一致」エラーが発生することがあります。</p>



<pre class="wp-block-code"><code>'--- これはエラーになる場合がある ---
Dim s As String
s = Range(&quot;A1&quot;).Value  '--- A1が数値だとエラー ---</code></pre>



<p class="wp-block-paragraph">対策は2つあります。<code>CStr</code>（値を文字列に変換する関数）で明示的に変換するか、<code>VarType</code> で文字列セルだけを処理対象にするかです。</p>



<h3 class="wp-block-heading"><span id="toc19">あいまいな名前のコンパイルエラー</span></h3>



<p class="wp-block-paragraph">複数のライブラリを参照設定していると、<code>Trim</code> という名前が衝突してコンパイルエラーが出ることがあります。「あいまいな名前が検出されました」というメッセージが表示されたら、<code>Strings.Trim</code> とフル修飾で書けば解決しますよ。</p>



<h3 class="wp-block-heading"><span id="toc20">マクロ無効・.xlsm保存の注意</span></h3>



<p class="wp-block-paragraph">VBAマクロを含むファイルは、必ず <strong>マクロ有効ブック（.xlsm）</strong> 形式で保存してください。通常の .xlsx 形式で保存すると、マクロのコードがすべて失われます。</p>



<p class="wp-block-paragraph">ファイルを開いたときに「マクロが無効にされました」と表示されたら、「コンテンツの有効化」をクリックしてください。</p>



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



<p class="wp-block-paragraph">VBA Trim関数のポイントを振り返っておきましょう。</p>



<ul class="wp-block-list"><li><strong>Trimは前後の空白を両方削除する関数</strong>。文字列内部の空白はそのまま残る</li><li>削除されるのは<strong>半角スペースのみ</strong>。全角スペース・タブ・NBSPは削除されない</li><li>空白がない文字列を渡してもエラーにならないので、安心してまとめて処理できる</li><li>業務では <code>UsedRange</code> を走査して、シート全体を一括クレンジングするのが定番</li><li>全角スペースやタブ・NBSPも消したいときは、TrimとReplace関数を組み合わせる</li></ul>



<p class="wp-block-paragraph">空白の処理は地味ですが、データの正確性に直結する大事な前処理です。Trimをうまく使って、クリーンなデータを手に入れましょう。</p>



<p class="wp-block-paragraph">前後どちらかだけ除去したいときは、<a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrim（先頭の空白削除）</a>や<a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrim（末尾の空白削除）</a>も使い分けてみてください。空白処理の全体像は、<a href="https://mashukabu.com/excel-vba-howto-remove-space/">VBA空白削除まとめ</a>で一覧できます。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-vba-howto-use-trim/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>VBAで空白を削除する方法｜Trim・Replace・全角スペースの対処法まとめ</title>
		<link>https://mashukabu.com/excel-vba-howto-remove-space/</link>
					<comments>https://mashukabu.com/excel-vba-howto-remove-space/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Thu, 03 Mar 2022 13:16:29 +0000</pubDate>
				<category><![CDATA[VBA・マクロ]]></category>
		<category><![CDATA[LTrim]]></category>
		<category><![CDATA[Replace]]></category>
		<category><![CDATA[RTrim]]></category>
		<category><![CDATA[Trim]]></category>
		<category><![CDATA[VBA]]></category>
		<category><![CDATA[データクレンジング]]></category>
		<category><![CDATA[マクロ]]></category>
		<category><![CDATA[文字列操作]]></category>
		<category><![CDATA[空白削除]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=1278</guid>

					<description><![CDATA[VBAで空白を削除するTrim・LTrim・RTrim・Replaceの使い方と使い分けを解説。全角スペースやNBSPなどTrimで消えない空白の原因特定と対処法も紹介。コピペで使えるコード付き。]]></description>
										<content:encoded><![CDATA[
<p class="wp-block-paragraph">ExcelのVBAでセルの空白を削除しようとしたのに、Trimをかけても消えない空白が残っていた。そんな経験はありませんか？</p>



<p class="wp-block-paragraph">空白が残ったままだと、VLOOKUPで#N/Aエラーが出たり、集計結果がずれたりします。放置するほど手戻りが増えて厄介です。</p>



<p class="wp-block-paragraph">VBAには空白を削除する関数が4つあります。空白の位置と種類に応じて使い分ければ、どんな空白トラブルも解決できますよ。</p>



<p class="wp-block-paragraph">この記事では、Trim・LTrim・RTrim・Replaceの使い方と使い分けを、コピペで動くコード付きで解説します。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>NOTE</strong></p><p>この記事のコードを実行するには、VBE（Visual Basic Editor）を開いて標準モジュールにコードを貼り付けます。<strong>Alt + F11</strong> でVBEを起動し、<strong>挿入</strong> → <strong>標準モジュール</strong> で編集画面を表示してください。VBEの詳しい使い方は <a href="https://mashukabu.com/excel-vba-vbe-menu-explanation/">VBEの画面の見方と基本操作</a> で解説しています。</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">VBAで空白を削除する4つの方法を整理しよう</a><ol><li><a href="#toc2" tabindex="0">Trim関数 ── 前後の半角スペースをまとめて削除</a></li><li><a href="#toc3" tabindex="0">LTrim関数 ── 先頭の半角スペースだけ削除</a></li><li><a href="#toc4" tabindex="0">RTrim関数 ── 末尾の半角スペースだけ削除</a></li><li><a href="#toc5" tabindex="0">Replace関数 ── 指定した文字をすべて削除</a></li></ol></li><li><a href="#toc6" tabindex="0">VBA TrimとワークシートTRIM関数の違い</a></li><li><a href="#toc7" tabindex="0">空白トラブル3パターン別の使い分けガイド</a><ol><li><a href="#toc8" tabindex="0">パターン1: 前後の半角スペースが邪魔 → Trim</a></li><li><a href="#toc9" tabindex="0">パターン2: 全角スペースが混ざっている → Replace</a></li><li><a href="#toc10" tabindex="0">パターン3: 見えない特殊空白（NBSPなど） → Replace + Chr</a></li></ol></li><li><a href="#toc11" tabindex="0">実践コード｜セル範囲の空白をまとめて一括削除する</a><ol><li><a href="#toc12" tabindex="0">指定範囲の前後スペースを一括Trim</a></li><li><a href="#toc13" tabindex="0">全角・NBSP対応の汎用クレンジングマクロ</a></li></ol></li><li><a href="#toc14" tabindex="0">空白の種類と対処法の早見表</a></li><li><a href="#toc15" tabindex="0">よくあるエラーと対処法</a><ol><li><a href="#toc16" tabindex="0">Trimしても空白が消えない場合の特定方法</a></li></ol></li><li><a href="#toc17" tabindex="0">まとめ</a><ol><li><a href="#toc18" tabindex="0">関連記事</a></li></ol></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">VBAで空白を削除する4つの方法を整理しよう</span></h2>



<p class="wp-block-paragraph">Excel VBAで空白を削除する方法は、大きく4つあります。まずは全体像を把握しておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>削除対象</th><th>特徴</th></tr></thead><tbody><tr><td>Trim</td><td>前後の半角スペース</td><td>もっとも基本的な空白除去</td></tr><tr><td>LTrim</td><td>先頭の半角スペース</td><td>左側だけ削除したいときに</td></tr><tr><td>RTrim</td><td>末尾の半角スペース</td><td>右側だけ削除したいときに</td></tr><tr><td>Replace</td><td>指定した文字すべて</td><td>全角スペースやNBSPにも対応</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">ポイントは、<strong>Trim系の3関数は半角スペース（Chr(32)）しか消せない</strong>ということです。「VBA Trimで全角スペースも消せる」という情報を見かけますが、これは誤りなので注意してください。</p>



<p class="wp-block-paragraph">全角スペースや特殊な空白を消すには、Replace関数の出番になります。</p>



<h3 class="wp-block-heading"><span id="toc2">Trim関数 ── 前後の半角スペースをまとめて削除</span></h3>



<p class="wp-block-paragraph">Trim関数は、文字列の<strong>先頭と末尾</strong>にある半角スペースをまとめて削除します。</p>



<pre class="wp-block-code"><code>Sub TrimExample()
    Dim s As String
    s = &quot;  Hello World  &quot;
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    ' 結果: [Hello World]
    ' ※ 文字列中間のスペースはそのまま残る
End Sub</code></pre>



<p class="wp-block-paragraph">前後だけ削除したいなら、Trimが一番シンプルです。詳しい使い方は <a href="https://mashukabu.com/excel-vba-howto-use-trim/">Trimで前後の空白を一括削除する方法</a> で解説しています。</p>



<h3 class="wp-block-heading"><span id="toc3">LTrim関数 ── 先頭の半角スペースだけ削除</span></h3>



<p class="wp-block-paragraph">LTrimは、文字列の<strong>先頭（左側）</strong>にある半角スペースだけを削除します。</p>



<pre class="wp-block-code"><code>Sub LTrimExample()
    Dim s As String
    s = &quot;   Hello World   &quot;
    Debug.Print &quot;[&quot; &amp; LTrim(s) &amp; &quot;]&quot;
    ' 結果: [Hello World   ]
    ' ※ 末尾のスペースは残る
End Sub</code></pre>



<p class="wp-block-paragraph">基幹システムから出力された固定長データなど、先頭のパディングだけ消したい場面で役立ちますよ。詳しくは <a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrimで先頭の空白を一括削除する方法</a> をご覧ください。</p>



<h3 class="wp-block-heading"><span id="toc4">RTrim関数 ── 末尾の半角スペースだけ削除</span></h3>



<p class="wp-block-paragraph">RTrimは、文字列の<strong>末尾（右側）</strong>にある半角スペースだけを削除します。</p>



<pre class="wp-block-code"><code>Sub RTrimExample()
    Dim s As String
    s = &quot;   Hello World   &quot;
    Debug.Print &quot;[&quot; &amp; RTrim(s) &amp; &quot;]&quot;
    ' 結果: [   Hello World]
    ' ※ 先頭のスペースは残る
End Sub</code></pre>



<p class="wp-block-paragraph">CSVインポート時に末尾へ付く余分なスペースを消すときに便利です。詳しくは <a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrimで末尾の空白を一括削除する方法</a> を参考にしてください。</p>



<h3 class="wp-block-heading"><span id="toc5">Replace関数 ── 指定した文字をすべて削除</span></h3>



<p class="wp-block-paragraph">Replace関数は、文字列の中から<strong>指定した文字をすべて置換（削除）</strong>できます。</p>



<pre class="wp-block-code"><code>Sub ReplaceExample()
    Dim s As String
    s = &quot;Hello World&quot;
    Debug.Print &quot;[&quot; &amp; Replace(s, &quot; &quot;, &quot;&quot;) &amp; &quot;]&quot;
    ' 結果: [HelloWorld]
    ' ※ 文字列中のすべての半角スペースが消える
End Sub</code></pre>



<p class="wp-block-paragraph">Trim系では対応できない<strong>全角スペース</strong>や<strong>ノーブレークスペース（NBSP）</strong>も、Replace関数なら削除できます。</p>



<p class="wp-block-paragraph">ただしReplace関数には注意点があります。<strong>第4引数（start）を指定すると、その位置より前の文字が戻り値から切り捨てられます</strong>。</p>



<pre class="wp-block-code"><code>Sub ReplaceStartTrap()
    Debug.Print Replace(&quot;ABCABC&quot;, &quot;A&quot;, &quot;X&quot;, 3)
    ' 結果: CXBC
    ' ※ 3文字目以降が処理対象になり、1〜2文字目の&quot;AB&quot;が消える
End Sub</code></pre>



<p class="wp-block-paragraph">start引数を使う場面は少ないですが、知らないとハマるポイントです。基本的には省略して使いましょう。</p>



<h2 class="wp-block-heading"><span id="toc6">VBA TrimとワークシートTRIM関数の違い</span></h2>



<p class="wp-block-paragraph">VBAのTrimと、ワークシート関数のTRIMは名前が同じですが動作が違います。ここを混同すると「消えるはずの空白が消えない」トラブルの原因になります。</p>



<figure class="wp-block-table"><table><thead><tr><th>比較項目</th><th>VBA Trim</th><th>ワークシートTRIM</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>NBSP (Chr(160))</td><td>削除しない</td><td>削除しない</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">最大の違いは<strong>中間スペースの扱い</strong>です。ワークシートTRIMは連続する半角スペースを1つにまとめますが、VBA Trimは中間のスペースに一切触れません。</p>



<p class="wp-block-paragraph">VBAからワークシートTRIMを使いたい場合は、次のように書きます。</p>



<pre class="wp-block-code"><code>Sub WorksheetTrimExample()
    Dim s As String
    s = &quot;Hello    World&quot;

    ' VBA Trim → 中間スペースはそのまま
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    ' 結果: [Hello    World]

    ' ワークシートTRIM → 中間スペースを1つに
    Debug.Print &quot;[&quot; &amp; WorksheetFunction.Trim(s) &amp; &quot;]&quot;
    ' 結果: [Hello World]
End Sub</code></pre>



<p class="wp-block-paragraph">中間の余分なスペースもまとめて処理したいときは、<code>WorksheetFunction.Trim</code> を使ってみてください。ワークシートのTRIM関数について詳しくは <a href="https://mashukabu.com/excel-function-howto-use-trim/">TRIM関数の使い方</a> で解説しています。</p>



<h2 class="wp-block-heading"><span id="toc7">空白トラブル3パターン別の使い分けガイド</span></h2>



<p class="wp-block-paragraph">「どの関数を使えばいいの？」と迷ったら、空白の種類で判断しましょう。業務でよく遭遇する3パターンに分けて解説します。</p>



<h3 class="wp-block-heading"><span id="toc8">パターン1: 前後の半角スペースが邪魔 → Trim</span></h3>



<p class="wp-block-paragraph">CSVインポートや基幹システム出力で混入しやすいパターンです。前後の半角スペースだけが問題なら、Trimで十分対応できます。</p>



<pre class="wp-block-code"><code>Sub Pattern1_Trim()
    Dim s As String
    s = &quot;  東京都  &quot;
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    ' 結果: [東京都]
End Sub</code></pre>



<p class="wp-block-paragraph">固定長フィールドのパディング除去にも、このパターンが当てはまります。まずはTrimを試してみてください。</p>



<h3 class="wp-block-heading"><span id="toc9">パターン2: 全角スペースが混ざっている → Replace</span></h3>



<p class="wp-block-paragraph">日本語入力の切り替え忘れで混入しやすいのが全角スペースです。Trim系では全角スペースを削除できないため、Replaceを使います。</p>



<pre class="wp-block-code"><code>Sub Pattern2_ZenkakuSpace()
    Dim s As String
    s = &quot;東京都　港区&quot;

    ' Trimでは消えない
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    ' 結果: [東京都　港区]

    ' Replaceで全角スペースを削除
    Debug.Print &quot;[&quot; &amp; Replace(s, &quot;　&quot;, &quot;&quot;) &amp; &quot;]&quot;
    ' 結果: [東京都港区]
End Sub</code></pre>



<p class="wp-block-paragraph">全角スペースはChr(12288)でも指定できます。日本語データを扱うなら、覚えておくと便利ですよ。</p>



<h3 class="wp-block-heading"><span id="toc10">パターン3: 見えない特殊空白（NBSPなど） → Replace + Chr</span></h3>



<p class="wp-block-paragraph">Webページからのコピペで混入するのが、ノーブレークスペース（NBSP、Chr(160)）です。見た目はただの空白ですが、Trimでは消せません。</p>



<pre class="wp-block-code"><code>Sub Pattern3_NBSP()
    Dim s As String
    s = &quot;東京都&quot; &amp; Chr(160) &amp; &quot;港区&quot;

    ' Trimでは消えない
    Debug.Print &quot;[&quot; &amp; Trim(s) &amp; &quot;]&quot;
    ' 結果: [東京都 港区]

    ' Replace + Chr(160)で削除
    Debug.Print &quot;[&quot; &amp; Replace(s, Chr(160), &quot;&quot;) &amp; &quot;]&quot;
    ' 結果: [東京都港区]
End Sub</code></pre>



<p class="wp-block-paragraph">NBSPが混入すると、VLOOKUPで完全一致のはずなのに#N/Aエラーが出る原因になります。目に見えないだけに原因特定が難しいトラブルです。NBSPの詳しい対策は <a href="https://mashukabu.com/about-nbsp/">ノーブレークスペース完全対策ガイド</a> で解説しています。</p>



<h2 class="wp-block-heading"><span id="toc11">実践コード｜セル範囲の空白をまとめて一括削除する</span></h2>



<p class="wp-block-paragraph">ここからは、実際の業務で使える実践コードを紹介します。セル範囲に対して一括で空白を削除できるマクロです。</p>



<h3 class="wp-block-heading"><span id="toc12">指定範囲の前後スペースを一括Trim</span></h3>



<p class="wp-block-paragraph">選択したセル範囲の前後半角スペースをまとめて削除するマクロです。</p>



<pre class="wp-block-code"><code>Sub TrimSelectedRange()
    Dim rng As Range
    Dim cell As Range

    Set rng = Selection

    For Each cell In rng
        If cell.Value &lt;&gt; &quot;&quot; Then
            cell.Value = Trim(cell.Value)
        End If
    Next cell

    MsgBox rng.Count &amp; &quot;セルのTrim処理が完了しました&quot;
End Sub</code></pre>



<p class="wp-block-paragraph">セル範囲を選択してからマクロを実行するだけでOKです。<a href="https://mashukabu.com/vba-howto-use-for-each-next/">For Each文</a> を応用した書き方になっています。</p>



<h3 class="wp-block-heading"><span id="toc13">全角・NBSP対応の汎用クレンジングマクロ</span></h3>



<p class="wp-block-paragraph">半角スペース・全角スペース・NBSPをまとめて除去する汎用版です。</p>



<pre class="wp-block-code"><code>Sub CleanseSpaces()
    Dim rng As Range
    Dim cell As Range
    Dim tmp As String

    Set rng = Selection

    For Each cell In rng
        If cell.Value &lt;&gt; &quot;&quot; Then
            tmp = cell.Value
            tmp = Replace(tmp, Chr(12288), &quot;&quot;)
            tmp = Replace(tmp, Chr(160), &quot;&quot;)
            tmp = Trim(tmp)
            cell.Value = tmp
        End If
    Next cell

    MsgBox rng.Count &amp; &quot;セルのクレンジングが完了しました&quot;
End Sub</code></pre>



<p class="wp-block-paragraph">処理の順番がポイントです。先にReplaceで全角・NBSPを消してから、最後にTrimで前後の半角スペースを仕上げます。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>NOTE</strong></p><p>マクロを保存するときは、ファイル形式を<strong>Excelマクロ有効ブック（.xlsm）</strong>にしてください。通常の.xlsx形式で保存すると、マクロが消えてしまいます。</p></blockquote>



<h2 class="wp-block-heading"><span id="toc14">空白の種類と対処法の早見表</span></h2>



<p class="wp-block-paragraph">業務データに混入しやすい空白を一覧にまとめました。</p>



<figure class="wp-block-table"><table><thead><tr><th>空白の種類</th><th>文字コード</th><th>主な混入経路</th><th>Trimで消える？</th><th>Replace削除方法</th></tr></thead><tbody><tr><td>半角スペース</td><td>Chr(32)</td><td>CSV末尾、手入力</td><td>前後のみ消える</td><td><code>Replace(s, " ", "")</code></td></tr><tr><td>全角スペース</td><td>Chr(12288)</td><td>日本語入力切替忘れ</td><td>消えない</td><td><code>Replace(s, Chr(12288), "")</code></td></tr><tr><td>NBSP</td><td>Chr(160)</td><td>Webコピペ</td><td>消えない</td><td><code>Replace(s, Chr(160), "")</code></td></tr><tr><td>タブ</td><td>Chr(9)</td><td>TSVインポート</td><td>消えない</td><td><code>Replace(s, Chr(9), "")</code></td></tr><tr><td>改行（LF）</td><td>Chr(10)</td><td>セル内改行</td><td>消えない</td><td><code>Replace(s, Chr(10), "")</code></td></tr><tr><td>改行（CR+LF）</td><td>Chr(13)+Chr(10)</td><td>他システム連携</td><td>消えない</td><td><code>Replace(s, vbCrLf, "")</code></td></tr></tbody></table></figure>



<p class="wp-block-paragraph">困ったときはこの表を見ながら、該当するReplace文をコードに追加してみてください。</p>



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



<p class="wp-block-paragraph">空白削除の処理でつまずきやすいポイントをまとめました。</p>



<figure class="wp-block-table"><table><thead><tr><th>症状</th><th>原因</th><th>対処法</th></tr></thead><tbody><tr><td>Trimしても空白が消えない</td><td>全角スペースやNBSPが混在</td><td>Replace + Chr で個別削除</td></tr><tr><td>Replace実行でエラー</td><td>Null値のセルを処理</td><td><code>If Not IsNull(cell.Value)</code> で事前チェック</td></tr><tr><td>Replaceで文字が欠ける</td><td>start引数を指定した</td><td>start引数を省略する</td></tr><tr><td>VLOOKUPが#N/Aになる</td><td>見えない空白が不一致の原因</td><td>Trim + Replaceでクレンジング後にVLOOKUP</td></tr><tr><td>ワークシートTrimと結果が違う</td><td>中間スペースの扱いが異なる</td><td><code>WorksheetFunction.Trim</code> を使う</td></tr></tbody></table></figure>



<p class="wp-block-paragraph">特に注意したいのが、<strong>TrimとReplaceのNull耐性の違い</strong>です。</p>



<pre class="wp-block-code"><code>Sub NullHandling()
    Dim v As Variant
    v = Null

    Debug.Print IsNull(Trim(v))
    ' 結果: True（Nullが返る＝エラーにならない）

    ' Replace(v, &quot; &quot;, &quot;&quot;)  ← エラーになる
End Sub</code></pre>



<p class="wp-block-paragraph">セル範囲を一括処理するときは、<code>If Not IsNull(cell.Value)</code> のチェックを入れておくと安全ですよ。</p>



<h3 class="wp-block-heading"><span id="toc16">Trimしても空白が消えない場合の特定方法</span></h3>



<p class="wp-block-paragraph">「Trimしたのに空白が残っている」ときは、AscW関数で文字のUnicodeコードポイントを調べましょう。</p>



<pre class="wp-block-code"><code>Sub InspectCharCodes()
    Dim s As String
    Dim i As Long

    s = Range(&quot;A1&quot;).Value

    For i = 1 To Len(s)
        Debug.Print &quot;位置&quot; &amp; i &amp; &quot;: &quot; &amp; Mid(s, i, 1) &amp; _
                    &quot; → AscW=&quot; &amp; AscW(Mid(s, i, 1))
    Next i
End Sub</code></pre>



<p class="wp-block-paragraph">AscW=32なら半角スペース、160ならNBSP、12288なら全角スペースです。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>NOTE</strong></p><p>Asc関数はANSIコードを返しますが、AscW関数はUnicodeコードポイントを返します。日本語環境ではAscWを使うのがおすすめです。</p></blockquote>



<p class="wp-block-paragraph">文字コードがわかれば、対応するReplace文を書くだけで解決できます。</p>



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



<p class="wp-block-paragraph">VBAで空白を削除する4つの関数の使い分けをおさらいしましょう。</p>



<ul class="wp-block-list"><li><strong>Trim</strong> ── 前後の半角スペースを削除。基本はこれでOK</li><li><strong>LTrim / RTrim</strong> ── 先頭・末尾だけ削除したいときに</li><li><strong>Replace</strong> ── 全角スペース・NBSP・タブなど、Trimで消せない空白に対応</li></ul>



<p class="wp-block-paragraph">データのクレンジングでは、Trim単体ではなくReplaceと組み合わせるのが鉄板パターンです。汎用クレンジングマクロをコピペして、日常業務に役立ててみてください。</p>



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



<ul class="wp-block-list"><li><a href="https://mashukabu.com/excel-vba-howto-use-trim/">Trimで前後の空白を一括削除する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-use-ltrim/">LTrimで先頭の空白を一括削除する方法</a></li><li><a href="https://mashukabu.com/excel-vba-howto-use-rtrim/">RTrimで末尾の空白を一括削除する方法</a></li><li><a href="https://mashukabu.com/about-nbsp/">ノーブレークスペース完全対策ガイド</a></li><li><a href="https://mashukabu.com/excel-function-howto-use-trim/">TRIM関数の使い方</a></li><li><a href="https://mashukabu.com/excel-function-howto-use-substitute/">SUBSTITUTE関数の使い方</a></li><li><a href="https://mashukabu.com/vba-howto-use-for-each-next/">For Each文の使い方</a></li><li><a href="https://mashukabu.com/excel-vba-howto-get-lastrow/">VBA 最終行取得の方法</a></li></ul>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/excel-vba-howto-remove-space/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
