VBA技術解説
フォルダー・ファイル・ブック・シートの文字制限

ExcelマクロVBAの問題点と解決策、VBAの技術的解説
最終更新日:2020-04-04

フォルダー・ファイル・ブック・シートの文字制限

フォルダーの作成、ファイルの作成、ブックの作成、シートの作成、
これらには指定できない文字があります、使用可能な文字に制限があります、
特にシートの文字制限について間違った解説が結構見受けられます。


フォルダ・ファイル・ブックの文字制限

フォルダ・ファイル・ブックの使用不可文字は以下になります。

\ 円記号
/ スラッシュ
: コロン
* アスタリスク
? 疑問符
" ダブルクォーテーション
< 不等号
> 不等号
| 縦棒

以上の半角文字は使用できません。
ただし、全角文字は使用できます。

以下は、使用不可文字が含まれているかの判定Functionになります。

Function CheckName(ByVal strName As String) As Boolean
  Dim strWrong  As Variant
  Dim i As Integer
  strWrong = Array("\", "/", ":", "*", "<", ">", "|")
  For i = LBound(strWrong) To UBound(strWrong)
    If InStr(strName, strWrong(i)) > 0 Then
      CheckName = False
      Exit Function
    End If
  Next
  CheckName = True
End Function

使用不可文字が含まれていないか1文字ずつチェックしています。
使用方法としては、

Sub sample()
  Dim strName As String
  strName = "abcd<123.xls"
  If CheckName(strName) = False Then
    MsgBox "使用できない文字があります。"
  End If
End Sub

このように使います。
もちろん、フォルダ・ファイルの存在確認も必要です。
Dir関数でチェックすればよいでしょう。
Dir関数は、指定したパターンやファイル属性と一致するファイルまたはフォルダの名前を返します、ドライブのボリュームラベルも取得できます、文字列型(String)の値を返します。Dir関数 Dir[(pathname[,attributes])] pathname 省略可能です。
具体的なサンプルとしては、第79回.ファイル操作Ⅰ(Dir)こちらで詳しく解説しています。
・Dir関数 ・Dir関数の使用例 ・Dir関数の実践例 ・Dir関数の制限について ・Dir関数の関連記事

シートの文字制限

シートの使用不可文字は以下になります。

: コロン
\ 円記号
/ スラッシュ
? 疑問符
* アスタリスク
[ 左角かっこ
] 右角かっこ

以上、半角・全角、どちらも使用できません。
WEB上では、この全角の場合が考慮されていない場合が多く見受けられます。

Function CheckName(ByVal strName As String) As Boolean
  Dim strWrong  As Variant
  Dim i As Integer
  strWrong = Array(":", "\", "/", "?", "*", "[", "]")
  For i = LBound(strWrong) To UBound(strWrong)
    If InStr(strName, strWrong(i)) > 0 Then
      CheckName = False
      Exit Function
    End If
    If InStr(strName, StrConv(strWrong(i), vbWide)) > 0 Then
      CheckName = False
      Exit Function
    End If
  Next
  CheckName = True
End Function

使用不可文字が含まれていないか1文字ずつチェックしています。
使用方法としては、

Sub sample()
  Dim strName As String
  strName = "abcd12/3.xls"
  If CheckName(strName) = False Then
    MsgBox "使用できない文字があります。"
  End If
End Sub

このように使います。

もちろん、シートの存在確認が必要になってきます。
シート名のチェックは結構面倒です。
大文字・小文字、全角・半角を区別せずにチェックする必要があります。

Function SheetExists(ByVal strName As String) As Boolean
  Dim sht As Object
  For Each sht In Sheets
    If StrConv(LCase(sht.Name), vbNarrow) = StrConv(LCase(strName), vbNarrow) Then
      SheetExists = False
      Exit Function
    End If
  Next
  SheetExists = True
End Function

使い方は、前記と同様になります。

指定できない文字のチェックや存在確認は以外と面倒なものです。
かといって、
実際に作って、On Errorでエラーを補足して対処したほうが早いという場合もあります。
しかし一度、上記のFunctionを作ってしまえば、後は使いまわせますよね。
やはり、ちゃんと事前にチェックした方が良いと思います。

後日追記

上記VBAはシートに使用可能な文字かの判定を完全には網羅できていません。
より厳密なシート名の制限
・31文字以内
・「履歴」は予約語として使えない
・先頭「'」シングルクォーテーションは使えない
・以下の文字は使用不可
 vbNullChar
 :\/?*[]
 :\/?*[]\
これらを考慮したマクロVBAについて以下でサンプルVBAを掲載しています。
新規挿入可能なシート名の判定
・シート名として使える文字列か判定 ・シートの存在確認:存在すればシートのオブジェクトを返す ・シートの挿入:存在すればシートのオブジェクトを返す



同じテーマ「マクロVBA技術解説」の記事

入力規則のドロップダウンが消えてしまうマクロ(Shapes内のDrop Down)
実行時にトラップ可能なエラー番号一覧
フォルダー・ファイル・ブック・シートの文字制限
Excel2013におけるScreenUpdatingの問題点
Dir関数の制限について
よくあるVBA実行時エラーの解説と対応
Application.Goto使用時の注意
ScreenUpdating=False時にエラー停止後にシートが固まったら
標準スタイル違いの問題点:標準フォント複写、列幅をピクセルで合わせる
VBAでエラー行位置(行番号)を取得できるErl関数


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

シートコピー後のアクティブシートは何か|ツイッター出題回答 (2023-09-19)
Excel関数の引数を省略した場合について|ツイッター出題回答 (2023-09-14)
セル個数を返すRange.CountLargeプロパティとは|VBA技術解説(2023-09-08)
記号を繰り返してグラフ作成(10単位で折り返す)|ツイッター出題回答 (2023-08-28)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-08-24)
ランクによりボイントを付ける(同順位はポイントを分割)|ツイッター出題回答 (2023-08-22)
OneDrive使用時のThisWorkbook.Pathの扱い方|VBA技術解説(2023-07-26)
列幅不足による###表示や指数表示を判定する|VBA技術解説(2023-07-12)
シートを削除:不定数のシート名に対応|VBAサンプル集(2023-07-04)
シート関数のCOUNTIFS,SUMIFS,MAXIFSと同じ処理|Power Query(M言語)入門(2023-02-28)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.繰り返し処理(For Next)|VBA入門
4.変数宣言のDimとデータ型|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロとは?VBAとは?VBAでできること|VBA入門
7.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
8.並べ替え(Sort)|VBA入門
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.条件分岐(IF)|VBA入門




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

記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



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