![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?8acaa2e)
Access VBA での有効なパスチェック
お世話になっております。
Access2002 VBAで、画面入力されたパスが有効なら、
そこにテーブルの内容をExcel出力する。といったことをしているのですが、
画面入力されたパスが、
たとえば「C:\\\\\\tmp\\\\\\\」などと入力された場合、
フォルダチェックに用いているDir関数ではOKなのですが、
Excel出力するDoCmd.TransferSpreadsheetでエラーとなってしまいます。
ここでのエラーが、実行時エラー:2220なので、例外処理で拾っているのですが、
フォルダチェックの段階で、はじくよい方法はあるでしょうか?
例文です>
str_tmpPath = txt_Path.Value 'ここで「C:\\\\\\tmp\\\\\\\」と入力されたとする
'有効なパスかチェックする
If Dir(str_tmpPath, vbDirectory) = "" Then '上記のパスで通ってしまう。戻り値は"."
MsgBox "入力しなおして"
End
End If
str_SavePath = str_tmpPath & "ファイル名"
'Excel出力
DoCmd.TransferSpreadsheet acExport, acSpreadsheetTypeExcel9, テーブル名, str_SavePath, True 'ここで実行時エラー:2220が発生
以上、よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
FileSystemObjectのFolderExistsメソッドを使用すればうまくいくようです。
FileSystemObjectで検索してみてください。
回答が遅くなり、申し訳ありません。
結局、以下のように試してみましたがダメでした。
Private Sub コマンド271_Click()
Dim str_Path As String 'パス
Dim fFso As Object 'ファイルシステムオブジェクト
str_Path = txt_Path.Value
'フォルダの存在確認
Set fFso = CreateObject("Scripting.FileSystemObject")
If (fFso.FolderExists(str_Path) = False) Then
MsgBox "無効なパス"
End If
Set fFso = Nothing
End Sub
正常な記述じゃないと、認識しませんでした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAでの共有パスにつきまして 1 2023/03/04 17:24
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Visual Basic(VBA) Excel-VBAでのファイルの開き方 4 2023/02/14 11:01
- Visual Basic(VBA) VBA 参照先で選んだファイルをコピーし、出力先に別名で保存したい 8 2022/05/13 20:37
- Visual Basic(VBA) VBAでファイル名を指定して保存するとき 4 2023/03/26 21:55
- Excel(エクセル) エクセルVBAでチェックボックスにチェックを入れる 1 2022/09/14 00:52
- Excel(エクセル) エクセル VBA For Next 繰り返しの書き方を教えてください 6 2022/09/01 14:11
- Excel(エクセル) Excel VBA 指定セルに入力されているパスからシートをコピーして別のブックに転記するVBAのコ 2 2022/04/19 15:53
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Visual Basic(VBA) Accessフォームで全レコードを指定のExcelのセルへ転送し印刷する方法について 2 2022/09/08 18:23
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
deleteで開放するとエラーにな...
-
配列のオフセットおよび長さが...
-
VB6.0 パスが見つかりません
-
Excel vbaでフォルダー内のppt...
-
c#で他のアプリをアクティブに...
-
VC++6.0 警告抑制
-
スクリプトで通知領域にあるソ...
-
STEAM版BF4が起動しない
-
学校のChrome Bookのロックの解...
-
Windows10 バックアップで失敗...
-
ASRockのLED制御が出来ない
-
DVDshrink メモリリソースが足...
-
DROP BOX バックアップを削除し...
-
Thunderbird ローカルフォルダ...
-
windows2000のシステムイメージ...
-
YAMAHAルータの設定ファイルの...
-
ARCServerでバックアップ異常
-
特定のsteamゲームが起動前にク...
-
ARCserveのスケジュール設定に...
-
テープ装置について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
deleteで開放するとエラーにな...
-
配列のオフセットおよび長さが...
-
Excel vbaでフォルダー内のppt...
-
VB6.0 パスが見つかりません
-
TRACKER : error TRK0002:
-
VBA で警告音
-
VBA Selenium Google Chrome 操...
-
IEの操作(Busy)でエラーになる
-
エラー:ページにアクセスする...
-
エクセルのような表計算ソフトO...
-
<strong>は、重要・緊急・注意...
-
Access VBA での有効なパスチェ...
-
Androidアプリ開発をしようとし...
-
pythonのモジュールのエラーの原因
-
VC++6.0 警告抑制
-
スクリプトで通知領域にあるソ...
-
ITRONプログラミングについて
-
Dreamweaverでテンプレートが作...
-
QVTKWidget.hの入手方法を教えて
-
学校のChrome Bookのロックの解...
おすすめ情報