VBA関数
Spc関数

Excelマクロで必須のVBA関数を入門・初級・初心者向けに詳細解説
公開日:2013年5月以前 最終更新日:2025-06-15

Spc関数


Spc関数は、Print # ステートメントまたは Print メソッドで使用され、出力に指定された数のスペース文字を挿入します。
これにより、テキストの整形や出力レイアウトの調整を行うことができます。



Spc関数の構文

Spc(number)

number (必須):
データ型: Long
出力に挿入するスペースの数を指定する数値式です。

解説・制限事項等
  • Spc 関数は、ファイルに書き込む際(Print #ステートメント)や、イミディエイトウィンドウ、またはユーザーフォームのPrintメソッドなどでテキストを出力する際に使用します。
  • numberで指定された数だけ空白文字を生成します。
  • numberが0の場合、スペースは挿入されません。
  • numberが負の値の場合、エラーが発生します。
  • numberがシステムで利用可能な最大幅を超える場合、numberは最大幅に切り詰められます。
  • Spc関数は、タブ文字(Tab関数)とは異なり、出力位置をタブストップに移動させるのではなく、単純に指定された数の空白を挿入します。これにより、より厳密な文字位置の調整が可能です。
  • Print #ステートメントで使用する場合、各項目間はセミコロン(;)で区切るのが一般的です。

Spc関数の使用例

次のコード例では、Spc 関数を使って、ファイルやイミディエイトウィンドウへの出力にスペースを挿入する方法を示します。

Sub Spc_SimpleSample()

  Dim fileNum As Integer
  Dim filePath As String
  
  filePath = ThisWorkbook.Path & "\SpcTest.txt" ' 一時ファイルパス
  
  On Error GoTo ErrorHandler ' エラーハンドラ設定
  
  ' --- ファイルへの出力例 ---
  fileNum = FreeFile
  Open filePath For Output As #fileNum
  
  Print #fileNum, "名前:" & Spc(5) & "田中"
  Print #fileNum, "年齢:" & Spc(3) & "30歳"
  Print #fileNum, "部署:" & Spc(1) & "営業部"
  
  Close #fileNum
  
  MsgBox "ファイル '" & Dir(filePath) & "' にスペースを挿入して出力しました。内容を確認してください。", _
      vbInformation, "Spc 関数例 (ファイル)"
  
  ' --- イミディエイトウィンドウへの出力例 ---
  Debug.Print "商品名"; Spc(10); "価格"; Spc(5); "数量"
  Debug.Print "鉛筆"; Spc(12); "100"; Spc(6); "5"
  Debug.Print "消しゴム"; Spc(9); "50"; Spc(7); "10"
  
  MsgBox "イミディエイトウィンドウにも出力しました。Ctrl+Gで確認してください。", _
      vbInformation, "Spc 関数例 (Debug.Print)"
     
  ' テストファイルを削除
  Kill filePath

  Exit Sub

ErrorHandler:
  MsgBox "エラーが発生しました: " & Err.Description, vbCritical, "エラー"
  If fileNum <> 0 Then Close #fileNum
  If Dir(filePath) <> "" Then Kill filePath
End Sub

  • このコードでは、Print #ステートメントとDebug.Printを使ってSpc関数の動作を示しています。
  • ファイルへの出力例では、Spc(5)、Spc(3)、Spc(1)のように異なる数のスペースを挿入し、列の位置を揃えるような出力を試みています。
  • イミディエイトウィンドウへの出力例でも同様に、Debug.PrintでSpc関数を使用し、レポートのような整形された出力をシミュレートしています。Debug.Printの各項目間もセミコロン(;)で区切ることで、Spcで挿入されたスペースがそのまま適用されます。
  • Ctrl+Gを押してイミディエイトウィンドウを開くと、実行結果を確認できます。
  • エラーハンドリングと一時ファイルの削除も含まれています。


※本記事の作成にあたっては、生成AI(Gemini)を活用し一部の文章作成を行っています。最終的な内容は人間による確認・編集を経て掲載しています。


Office VBA リファレンス Spc関数

※VBA関数一覧
マクロVBA関数の一覧と解説です、どんな関数があるかは一度は確認しておくとをお勧めいたします。どんな関数があるだけでも知っておけば、詳細の使い方は実際に使うときに調べても良いでしょう。文字列操作…34 分岐…3 型変換…14 データ判定…10 日付時刻…20 配列…6 ファイル操作…14 数学/財務…28 その他……



同じテーマ「VBA関数」の記事

Loc関数
LOF関数
Seek関数
Spc関数
Tab関数
Abs関数
Int関数
Fix関数
Hex関数
Oct関数
Rnd関数


新着記事NEW ・・・新着記事一覧を見る

AIは便利なはずなのに…「AI疲れ」が次の社会問題になる|生成AI活用研究(2026-02-16)
カンマ区切りデータの行展開|エクセル練習問題(2026-01-28)
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法|エクセル雑感(2026-01-27)
IMPORTCSV関数(CSVファイルのインポート)|エクセル入門(2026-01-19)
IMPORTTEXT関数(テキストファイルのインポート)|エクセル入門(2026-01-19)
料金表(マトリックス)から金額で商品を特定する|エクセル練習問題(2026-01-14)
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭|エクセル雑感(2026-01-13)
シンギュラリティ前夜:AIは機械語へ回帰するのか|生成AI活用研究(2026-01-08)
電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
8.マクロとは?VBAとは?VBAでできること|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.メッセージボックス(MsgBox関数)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
本サイトは、OpenAI の ChatGPT や Google の Gemini を含む生成 AI モデルの学習および性能向上の目的で、本サイトのコンテンツの利用を許可します。
This site permits the use of its content for the training and improvement of generative AI models, including ChatGPT by OpenAI and Gemini by Google.



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ