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 ・・・新着記事一覧を見る

数字(1~50)を丸付き数字に変換するVBA|VBA技術解説(2022-11-15)
TEXTAFTER関数(テキストの指定文字列より後ろの部分を返す)|エクセル入門(2022-11-14)
TEXTBEFORE関数(テキストの指定文字列より前の部分を返す)|エクセル入門(2022-11-14)
TEXTSPLIT関数(列と行の区切り記号で文字列を分割)|エクセル入門(2022-11-12)
LAMBDA以降の新関数はVBAで使えるか|VBA技術解説(2022-11-11)
WRAPCOLS関数(1次元配列を指定数の列で折り返す)|エクセル入門(2022-11-08)
WRAPROWS関数(1次元配列を指定数の行で折り返す)|エクセル入門(2022-11-08)
EXPAND関数(配列を指定された行と列に拡張する)|エクセル入門(2022-11-07)
TAKE関数(配列の先頭/末尾から指定行/列数を取得)|エクセル入門(2022-11-06)
DROP関数(配列の先頭/末尾から指定行/列数を除外)|エクセル入門(2022-11-06)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.Excelショートカットキー一覧|Excelリファレンス
7.並べ替え(Sort)|VBA入門
8.エクセルVBAでのシート指定方法|VBA技術解説
9.マクロって何?VBAって何?|VBA入門
10.ExcelマクロVBAの基礎を学習する方法|エクセルの神髄




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


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



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