VBAで文字列を扱う際、不要な空白を削除したい!と感じる瞬間はありませんか?
この記事では、VBAで文字列のスペースを削除する時に使えるTrim関数について詳しく解説していきます!
Trim関数とは?
Trim関数とは、文字列の先頭と末尾の空白を削除する関数です。文字列の中の空白文字を残したまま、余白を削除したい場合などに使用します。
Trim関数を使って空白を削除することで、Excelシート上のデータの見た目が揃って見やすくなったり、VBAで文字列を扱う処理がしやすくなったりといったメリットがあります。
【Trim関数の処理のイメージ】
使用する際は以下のように記述します。
【基本構文】
Trim(string)
引数の文字列にNull値が含まれている場合には、Nullが返されます。
Trim関数の使い方
具体的な使い方をサンプルコードで確認してみましょう。
【サンプルコード】
Sub sampleTrim()
Dim str As String
str = " Hello World! "
MsgBox "「Trim前:" & str & "」" & vbCrLf & _
"「Trim後:" & Trim(str) & "」"
End Sub
【実行結果】
文字列 “Hello World!” の先頭に半角スペースを、末尾に全角スペースを含めてみましたが、どちらも削除されているのが分かるかと思います。
ただし、削除されるのは先頭と末尾のスペースのみなので、文字列中のスペースはそのまま残っています。
LTrim関数、RTrim関数で片側の余白だけを削除する
Trim関数は文字列の前後にあるスペースを一度に削除しますが、このほかに先頭と末尾のそれぞれ片方のみを削除する関数も存在します。
・先頭のみを削除したい場合
LTrim(String)
・末尾のみを削除したい場合
RTrim(String)
サンプルコードで見てみましょう。
【サンプルコード】
Sub sampleTrim2()
Dim str As String
str = " Hello World! "
MsgBox "「LTrim:" & LTrim(str) & "」" & vbCrLf & _
"「RTrim:" & RTrim(str) & "」"
End Sub
【実行結果】
VBAで余分な改行・タブ・全角スペースを削除する
場合によっては、VBAを利用して余分な改行やタブ、文字間のスペースなどを削除したい時があるかもしれません。
これらはTrim関数で削除することはできないので、代わりにReplace関数を使用します。
Replace関数を使うと指定した文字を別の文字に置換することができるので、文字数0の空文字に置換することで余分な文字を削除します。
【サンプルコード】
Sub macro3()
Dim str As String
str = vbTab & "Hello World!" & vbCrLf
MsgBox "「Replace前:" & str & "」" & vbCrLf & _
"「スペース削除:" & Replace(str, " ", "") & "」" & vbCrLf & _
"「タブ削除:" & Replace(str, vbTab, "") & "」" & vbCrLf & _
"「改行削除:" & Replace(str, vbCrLf, "") & "」"
End Sub
【実行結果】
まとめ
今回は、文字列に含まれる空白などをVBAで削除する方法について解説してきました。
状況に合わせて、Trim関数やReplace関数を使い分けていきましょう!
関連記事
- VBAとは
- Excelで覚えておくべき17の基本関数と目的別逆引き一覧
- オートフィルターの設定・解除方法
- メッセージボックスの設定方法
- セルの値を取得・上書きするValueプロパティの使い方を解説
- 【Excel VBA】Functionの使い方を解説(宣言・引数、戻り値の指定、応用法)
VBAの勉強方法は?
書籍やインターネットで学習する方法があります。昨今では、YouTubeなどの動画サイトやエンジニアのコミュニティサイトなども充実していて多くの情報が手に入ります。
そして、より効率的に知識・スキルを習得するには、知識をつけながら実際に手を動かしてみるなど、インプットとアウトプットを繰り返していくことが重要です。特に独学の場合は、有識者に質問ができたりフィードバックをもらえるような環境があると、理解度が深まるでしょう。
ただ、VBAに限らず、ITスキルを身につける際、どうしても課題にぶつかってしまうことはありますよね。特に独学だと、わからない部分をプロに質問できる機会を確保しにくく、モチベーションが続きにくいという側面があります。独学でモチベーションを維持する自信がない人にはプログラミングスクールという手もあります。費用は掛かりますが、その分スキルを身につけやすいです。しっかりと知識・スキルを習得して実践に活かしたいという人はプログラミングスクールがおすすめです。
プログラミングスクールならテックマニアがおすすめ!
ITスキル需要の高まりとともにプログラミングスクールも増えました。しかし、どのスクールに通うべきか迷ってしまう人もいるでしょう。そんな方にはテックマニアをおすすめします!これまで多くのITエンジニアを育成・輩出してきたテックマニアでもプログラミングスクールを開講しています。
<テックマニアの特徴>
・たしかな育成実績と親身な教育 ~セカンドキャリアを全力支援~
・講師が現役エンジニア ~“本当”の開発ノウハウを直に学べる~
・専属講師が学習を徹底サポート ~「わからない」を徹底解決~
・実務ベースでスキルを習得 ~実践的な凝縮カリキュラム~
このような特徴を持つテックマニアはITエンジニアのスタートラインとして最適です。
話を聞きたい・詳しく知りたいという方はこちらからお気軽にお問い合わせください。