ExcelマクロVBA技術解説 | フォルダー・ファイル(ブック)・シートの文字制限 | Excelマクロの問題点と解決策、エクセル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関数でチェックすればよいでしょう。
具体的なサンプルとしては、第79回.ファイル操作T(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を作ってしまえば、後は使いまわせますよね。
やはり、ちゃんと事前にチェックした方が良いと思います。




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

Excel2013におけるScreenUpdatingの問題点
オートフィルタ(AutoFilter)の使い方まとめ
文字列としてのプロシージャー名を起動する方法(Run,OnTime)
ドキュメントの作成者を取得(GetObject,BuiltinDocumentProperties)
複雑な条件(複数除外等)のオートフィルター(AutoFilter)
条件付きコンパイル(32ビット64ビットの互換性)
Application.Goto使用時の注意

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

Excelファイルを開かずにシート名をチェック|ExcelマクロVBAサンプル集(3月23日)
数式の参照しているセルを取得する|ExcelマクロVBAサンプル集(3月18日)
CSVの読み込み方法(改の改)|ExcelマクロVBAサンプル集(3月17日)
変数とプロシージャーの命名について|ExcelマクロVBA技術解説(2月12日)
ファイルの一覧取得・削除(File)|Google Apps Script入門(1月24日)
フォルダの一覧取得・作成・削除(Folder)|Google Apps Script入門(1月24日)
フォルダとファイルを扱う(DriveApp)|Google Apps Script入門(1月24日)
スプレッドシートが非常に遅い、高速化するには|Google Apps Script入門(1月17日)
画像のトリミング(PictureFormat,Crop)|ExcelマクロVBAサンプル集(12月27日)
シート保護|Google Apps Script入門(12月24日)

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

1.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
2.RangeとCellsの使い方|ExcelマクロVBA入門
3.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
6.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
7.変数とデータ型(Dim)|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.CSVの読み込み方法|ExcelマクロVBAサンプル集
10.VBAのFindメソッドの使い方には注意が必要です|ExcelマクロVBA技術解説



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

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


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

    ↑ PAGE TOP