こんにちは、Excelでマクロを組んでいます。ネットワークにファイルサーバーのNasを利用しているのですが、ファイルを開くダイアログで初期表示されるディレクトリをNasのフォルダに指定したいと思っています。
ChDir "\\Nas\最初に開きたいフォルダ"
Application.GetOpenFilename
で指定しても、なぜかローカルのマイドキュメントが開かれてしまいます。ローカルのマイドキュメントはカレントディレクトリに設定されていますが、例えば
ChDir "C:\テストフォルダ名"としてから
Application.GetOpenFilename
とすると、きちんとテストフォルダ名が最初に表示されます。Nasへの接続の問題でしょうか?でも、Nasへログオンするにはユーザー名やパスワードを指定するはずなので、ログオンしていなかった場合はそれを聞いてくると思われるのですが・・・いかがでしょう?パスが間違っていたら、パスが間違っていますというエラーメッセージになると思いますし、、、よろしくお願いします。
No.5ベストアンサー
- 回答日時:
> もともとWindowsで設定されていたカレントディレクトリが変更されて
> しまいませんか?
良く意味がわかりませんが、それがカレントディレクトリを変更すると
いうことなのでは?
GetOpenFilename の時だけ変更したいなら...
Sub Sample()
Dim sDirPathBackup As String
Dim sFileName As String
' 現在のカレントディレクトリパスを退避
sDirPathBackup = CurDir
MsgBox CurDir, , "現在のカレントディレクトリ"
With CreateObject("WScript.Shell")
' カレントディレクトリ変更
.CurrentDirectory = "D:\AITEMP"
' ダイアログ開く
sFileName = Application.GetOpenFilename("EXCELファイル (*.xls), *.xls")
' カレントディレクトリを元に戻す
.CurrentDirectory = sDirPathBackup
End With
' 以後の処理継続~
MsgBox CurDir, , "元に戻ってます^^"
End Sub
この回答への補足
でもなんだかカレントディレクトリを変更した後、元に戻す必要はないのかな?と思ってきました。だって、ファイルを開くダイアログでファイルを開いたら、カレントディレクトリは開いたファイルのあるディレクトリになるわけですよね?そのあと、マイドキュメントにあるファイルを開いたら、カレントディレクトリはマイドキュになりますか?ごちゃごちゃですみません・・・
補足日時:2006/10/30 13:40エクセルに設定されていた保存先が変更されてしまうかと思ってしまいました。大丈夫みたいですね。現在のカレントディレクトリも一旦退避させて、ダイアログを開いた後にすぐ元にもどしてしまえばいいんですね。よくわかりました<^!^>、どうもありがとうございました。
No.4
- 回答日時:
#2 です。
誤解を招きそうなので補足しときます。確かに API もモノによって環境依存します。しかし、 SetCurrentDirectory API
は Win95~WinXPで大丈夫です。恐らくは次期 Windows Vista でも。
Windows の仕様変更を MS のアナウンス前から気にしていたらプログラムは
不可能ですから、現段階では心配無用だと思います。
WSH(Windows Scripting Host)は、Internet Explorer 4 以上がインストール
されていれば OS に標準的にインストールされてます。Win98 以降なら大丈夫
だったと思いますが、この点は確認してません。
Windows95等でブラウザのアップデートを全くしてない、WSH をインストール
していない PC だと動きません。
以前の LoveLetter ウイルス騒動で WSH を問題視したシステム管理者が WSH
禁止目的で、意図的に WSH をアンインストールしている場合も動きません。
この2点において API による方法に比べれば環境を選ぶ方法と言えますね。
が、ほとんどの PC で動くでしょう。
また、WSH は 次期 Windows Vista までは少なくとも搭載されると MS が
公式発表してます。今から心配する必要はありません。
No.3
- 回答日時:
No.1ですが、補足しておきます。
APIも環境に依存しますので、もし使用するのであればそれだけ注意してください。
(Windows系でもいきなりなくなったり仕様が変わったりすることもありますので)
WSHの方は将来無くなる予定です。
No.2
- 回答日時:
こんにちは。
KenKen_SP です。2 つの方法があります。お好みで。
ともに参照先が存在しない場合の例外処理が必要です。特に WSH の方は
エラーが発生して処理が中断されます。
▼ API を使う方法
Declare Function SetCurrentDirectory Lib "kernel32" Alias "SetCurrentDirectoryA" ( _
ByVal lpPathName As String _
) As Long
Sub Sample1()
Call SetCurrentDirectory("\\Nas\最初に開きたいフォルダ")
MsgBox CurDir
End Sub
▼ WSH を使う方法(環境依存しますが Win98 以降なら OK かな?)
Sub Sample2()
CreateObject("WScript.Shell").CurrentDirectory = "\\Nas\最初に開きたいフォルダ"
MsgBox CurDir
End Sub
この回答への補足
WSHを調べました。WSHが何であるかわかったのですが、WSHを利用した場合、もともとWindowsで設定されていたカレントディレクトリが変更されてしまいませんか?
補足日時:2006/10/30 11:52No.1
- 回答日時:
カレントドライブを変更しないとchdirは有効になりませんので、ご質問の
ケースはそのようになります。
逆に言えば、UNC名でカレントフォルダを指定することはできません。
方法としては、UNC名をネットワークドライブに割り当てた後、chdriveで
カレントドライブをそのネットワークドライブに変更し、それからchdir以降を
行えば可能だと思います。
ChDriveでドライブを変更してから行ってもできなかったんですよね・・・結局WSHで対応することにしました。APIやWSHについても今後について検討することができ、大変参考になりました。ご意見どうもありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 動かなくなってしまった古いVBAを動くようにしたい 8 2022/09/20 13:57
- Windows 10 外部ドライブにマウントできない問題について 9 2022/03/22 18:08
- Excel(エクセル) excelのマクロ実行でブロックされます。 2 2022/06/08 09:14
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/01/26 09:50
- Visual Basic(VBA) エクセルのマクロについて教えてください。 3 2023/02/17 11:59
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/05/26 17:13
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/02/20 10:00
- Excel(エクセル) エクセルのマクロについて教えてください。 2 2023/01/12 16:58
- Access(アクセス) エクセルのマクロについて教えてください。 2 2023/02/03 16:07
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/02/21 09:28
このQ&Aを見た人はこんなQ&Aも見ています
-
10代と話して驚いたこと
先日10代の知り合いと話した際、フロッピーディスクの実物を見たことがない、と言われて驚きました。今後もこういうことが増えてくるのかと思うと不思議な気持ちです。
-
3分あったら何をしますか?
カップ麺にお湯を入れて、できるまでの3分間で皆さんは何をしていますか?
-
モテ期を経験した方いらっしゃいますか?
一生に一度はモテ期があるといいますが、みなさんどうですか? いまがそう! という方も、「思い返せばこの頃だったなぁ」という方も、よかったら教えて下さい。
-
前回の年越しの瞬間、何してた?
いよいよ2025年がやってきますね。 年越しのスタイルは人それぞれ。 2024年を迎える瞬間は何をしていましたか?
-
店員も客も斜め上を行くデパートの福袋
シュールを通り越して店員も客も斜め上を行くデパートの福袋に入ってそうなものを教えて下さい。 よかったらレビューもしてください。
-
【Excel VBA】ネットワーク上の共有フォルダにあるExcelを開く
Excel(エクセル)
-
VBA ネットワーク上のファイルでカレントフォルダを取得するには?
Visual Basic(VBA)
-
会社のネットワーク上のファイルを開けない こんにちわ 今大変困ってます 会社のネットワーク上のファイ
Visual Basic(VBA)
-
-
4
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
5
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
6
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
7
VBA シートをコピーする際に Copyメソッドは失敗しましたのエラーが出てしまいます
Visual Basic(VBA)
-
8
【Excel VBA】マクロでExcel自体を終了させたい
Excel(エクセル)
-
9
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
10
Excelで指定したフォルダに保存するマクロ
Excel(エクセル)
-
11
vba 時間の引き算 例えば 15:00から16:15の間の時間は1時間15分ですが、vbaのコード
Visual Basic(VBA)
-
12
Excel マクロでShearePoint先のフォルダ指定
Excel(エクセル)
-
13
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
14
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
15
Excelでセル参照したとき、書式も一緒に持ってくるには?
Windows Vista・XP
-
16
エクセルVBAでオートフィルター最上行を取得するには
Excel(エクセル)
-
17
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
18
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
19
エクセルVBAで5行目からオートフィルタモードに設定したいたい
Excel(エクセル)
-
20
VBA(エクセル)で自動的にボタンをクリックさせるには
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・「黒歴史」教えて下さい
- ・2024年においていきたいもの
- ・我が家のお雑煮スタイル、教えて下さい
- ・店員も客も斜め上を行くデパートの福袋
- ・食べられるかと思ったけど…ダメでした
- ・【大喜利】【投稿~12/28】こんなおせち料理は嫌だ
- ・前回の年越しの瞬間、何してた?
- ・【お題】マッチョ習字
- ・モテ期を経験した方いらっしゃいますか?
- ・一番最初にネットにつないだのはいつ?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・2024年に成し遂げたこと
- ・3分あったら何をしますか?
- ・何歳が一番楽しかった?
- ・治せない「クセ」を教えてください
- ・【大喜利】【投稿~12/17】 ありそうだけど絶対に無いことわざ
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・集合写真、どこに映る?
- ・自分の通っていた小学校のあるある
- ・フォントについて教えてください!
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・10代と話して驚いたこと
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA ファイルを開くダイアログ...
-
Accessのデータベース格納場所の件
-
ユーザーフォルダの保存先をDド...
-
デスクトップの場所
-
マイドライブが表示されない
-
デフォルトでファイルを別ドラ...
-
CドライブとDドライブの関連付...
-
iTunesの保存先が変わってしま...
-
[クイックアクセスツールバー]...
-
D:自体、デスクトップにしてし...
-
XPでProgram Filesはどこにある...
-
Cドライブの中にDドライブがで...
-
Cドライブがダブルクリックで開...
-
Dドライブへの移動で「お気に...
-
フォルダの名前が全部同じにな...
-
デスクトップの保存先について...
-
USBメモリーをDドライブとして...
-
フォルダの削除について
-
コマンドプロンプト 閉じた時の...
-
Docuworks(ドキュワークス)の不...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA ファイルを開くダイアログ...
-
Cドライブに最低限必要なファイ...
-
Accessのデータベース格納場所の件
-
マイドライブが表示されない
-
デスクトップの場所
-
CD-EXTRAデータを閲覧したいの...
-
フォルダの名前が全部同じにな...
-
USBメモリーをDドライブとして...
-
デスクトップにファイルをその...
-
ドライブCからD移動 場所タ...
-
デフォルトでファイルを別ドラ...
-
フォルダ名(?)に本名が入っ...
-
ショートカットは作成しすぎな...
-
「デスクトップ」フォルダをDド...
-
ファイルは基本的にどこに保存...
-
[クイックアクセスツールバー]...
-
swapfile.sysとpagefile.sys
-
Windows7でデスクトップの保存...
-
DドライブのProgramFilesが表示...
-
Windows10でパブリックフォルダ...
おすすめ情報