![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?5a7ff87)
ExcelVBAの書き方で質問があります。
ファイル名やフォルダ名を指定して…
(1)フォルダにファイルが存在するかどうかを調べる方法
(2)フォルダが存在するかどうかを調べる方法
(3)ファイルが他のユーザーの使用中になっているかを調べる方法
現在は(1)については、Workbooks.Open Filename:=~でファイルが無ければ、On Error GoToで分岐させるといった方法を行っているのですが、もっとダイレクトに有無を調べる方法が知りたいのです。
(2)や(3)については、どうすればよいのやら?
初心者ですので、簡単な表現でお願いします。
よろしくご教授下さい。
No.2ベストアンサー
- 回答日時:
Sub Test()
'ディレクトリ存在チェック
MsgBox IsDir("C:\")
'排他状態
MsgBox IsNoOpen("C:\test.xls")
End Sub
'ディレクトリ存在チェック
'TRUE=存在している
Public Function IsDir(ByVal inDirName As String) As Boolean
Dim fsoObj As Object
Dim fsoDir As Object
On Error Resume Next
Set fsoObj = CreateObject("Scripting.FileSystemObject")
Set fsoDir = fsoObj.GetFolder(inDirName)
IsDir = Not (fsoDir Is Nothing)
Set fsoDir = Nothing
Set fsoObj = Nothing
End Function
'誰かがファイルを開いていないかをチェックする
'TRUE=編集可能状態で開くことができる
Public Function IsNoOpen(ByVal inXlsFileName As String) As Boolean
'ファイルが存在していないのは問題外でアウト
If Dir(inXlsFileName) = "" Then
Exit Function
End If
On Error Resume Next
'書き込み専用でオープンでエラーが発生しなければ、誰も開いていないとみなす
Open inXlsFileName For Binary Lock Read Write As #1
Close #1
IsNoOpen = (Err.Number = 0&)
End Function
No.1
- 回答日時:
ExcelVBAだけでファイルシステム関連の情報が入手できるかはわかりませんが、代替案としては「Microsoft Windows スクリプト テクノロジ」に含まれるWindows Script Hostの各種オブジェクトを利用する方法があります。
Microsoft Windows スクリプト テクノロジとは、JScriptやVBScriptの言語やScriptの実行環境、スクリプトから利用できるコンポーネントなどのことです。
Windows Script Hostには、各種機能を提供するCOMコンポーネントが多数含まれており、VBAからも呼び出すことが可能です。
作成したExcelVBAを配布する場合は、利用したコンポーネントがインストールされている必要があると思いますが、IEの5.x以上があればインストールされていると思うのですが・・・
(曖昧で申し訳ありません)
FSO(FileSystemObject)にはドライブ、フォルダ、ファイル関連の情報を取得することができるオブジェクトが多数含まれているので、利用すると便利だと思います。
参考URLも書きましたが、「FileSystemObject」で検索するといい情報が見つかると思います。
ExcelVBAの場合は、「Microsoft Scripting Runtime」を参照設定する必要があるかもしれません。
VBAはあまり使ったことがないので、解決になるかはわかりませんが、VBからはFileSystemObjectをよく使っている話を聞きます。
参考URL:http://www.microsoft.com/japan/msdn/library/defa …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/03/07 14:05
- Excel(エクセル) エクセルのマクロについて教えてください。 2 2023/02/21 13:29
- Visual Basic(VBA) Excelのマクロについて教えてください。 作業フォルダ内に2つのファイルがあります。 このファイル 2 2023/07/09 13:40
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/02/21 11:19
- UNIX・Linux Ubuntu でinvalid filenameとなるファイルをコピーする方法 3 2023/06/08 22:26
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/06/04 09:39
- Visual Basic(VBA) エクセルのマクロについて教えてください 物件ごとのフォルダを作成してます そのフォルダ内にサブフォル 2 2023/07/02 17:58
- XML エクセルのマクロについて教えてください。 3 2023/02/06 09:06
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/07/02 11:48
- フリーソフト ffmpegのパラメーター『-i』について 1 2023/03/09 07:19
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
特定のファイルを他のプロセスが編集中か確認する方法
Visual Basic(VBA)
-
VBでExcelが起動されているか知りたい
Visual Basic(VBA)
-
《エクセルVBA》「他の人が該当ファイルを使用中の場合」の処理
Excel(エクセル)
-
-
4
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
5
エクセルで誰が今開いているか調べる方法。
Excel(エクセル)
-
6
エクセルでエラーが出て困っています。
Excel(エクセル)
-
7
Excelのセルにユーザー名を表示する方法
Excel(エクセル)
-
8
【Excel VBA】マクロでExcel自体を終了させたい
Excel(エクセル)
-
9
「Columns(A:C")」の列文字を数字にして表記したい"
Excel(エクセル)
-
10
VBAでCSVファイルが使用中かどうかの確認
Visual Basic(VBA)
-
11
ネット上PCのエクセルのユーザーIDを検索したい
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイルやフォルダの有無、他...
-
FileExitsについて
-
何百台の社内端末移設をしてお...
-
ブラウザでASPファイルを開こう...
-
バッチによるショートカットの...
-
Excelでdatファイルを作成??
-
フォルダ作成用バッチファイル...
-
バッチファイルが作成できない
-
VBAからファイルをzip化したい
-
batファイル処理でのテキストフ...
-
Thunderbird ローカルフォルダ...
-
WebLogic/javaで一部JSPだけが...
-
VBAでFTPファイル転送がうまく...
-
John The Ripper
-
1フォルダに保存できるファイル...
-
【Excel VBA】PDFを作成して,...
-
フォルダ参照ではなくファイル...
-
ダウンロード不可PDFファイルは...
-
VBSで指定したフォルダにファイ...
-
OpenTextFile で書き込みできま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Access2003で「オブジェクト'○○...
-
FileExitsについて
-
BASP21を使わないファイルアッ...
-
ファイルやフォルダの有無、他...
-
VBScriptでファイルアップロー...
-
拡張子.vbsのファイルの外部フ...
-
サーバー上のファイルアクセス...
-
delphiネットワークドライブフ...
-
Excelでのデータ挿入が上手くで...
-
EXCELのプロセスを終了さ...
-
Excelでdatファイルを作成??
-
VBAでファイルパスが長すぎてコ...
-
Microsoft Access エラー 3051
-
拡張子が.txtのファイルに将来...
-
複数のテキストファイルをexcel...
-
バッチによるショートカットの...
-
フォルダ作成用バッチファイル...
-
Lubuntuでフォントをインストー...
-
バッチファイルが作成できない
-
batファイル処理でのテキストフ...
おすすめ情報