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

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

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

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


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

使用不可文字は以下になります。

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

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

以下は、使用不可文字が含まれているかの判定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)こちらで詳しく解説しています。
VBAでは、フォルダのファイル一覧を取得したりファイルの存在確認をする事が出来ます、指定したパターン(ワイルドカード)やファイル属性と一致するファイルまたはフォルダの名前を表す文字列の値を返します。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技術解説」の記事

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


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

ツイッターで出されたVBAのお題をやってみた|エクセル雑感(1月13日)
イベントプロシージャーの共通化(Enter,Exit)|ユーザーフォーム入門(1月13日)
Rangeオブジェクトの論理演算(差集合と排他的論理和)|VBA技術解説(1月10日)
イベントプロシージャーの共通化|ユーザーフォーム入門(1月7日)
コントロールの動的作成|ユーザーフォーム入門(1月6日)
Evaluateメソッド(文字列の数式を実行します)|VBA技術解説(1月5日)
エクスポート(PDF/XPS)|VBA入門(1月2日)
分析関数(OVER句,WINDOW句)|SQL入門(12月25日)
取得行数を限定するLIMIT句|SQL入門(12月21日)
外部ライブラリ(ActiveXオブジェクト)|VBA入門(12月21日)


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

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.変数宣言のDimとデータ型|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.マクロって何?VBAって何?|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.空白セルを正しく判定する方法(IsEmpty,IsError,HasFormula)|VBA技術解説
10.ひらがな⇔カタカナの変換|エクセル基本操作



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

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


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



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