質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

1回答

5240閲覧

Workbooks.Openをネストさせて、二回使用すると二回目が開けない

sokha

総合スコア216

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2016/04/06 09:51

編集2016/04/06 10:02

###前提・実現したいこと

Visual Basicにて、
Book1,Book2,Book3 がありそれぞれ
1)Book1に open -> book2を開く というコード
2)Book2に open -> book3を開く というコード
を書き、 Book1を開いた時、book3まで連鎖的に開けることを期待しました。

###発生している問題・エラーメッセージ
book3が開きません。
1,2の単独ですと動きます。
ですが、book1から開くと、エラーが返却されないにもかかわらず、なぜかbook2のコード内のWorkbooks.Open ("book2.xls").NameがBook1となるのです。
そしてWorkbooksにはbook3が入っていません。(開いていない)

###該当のソースコード

@book1

Sub Workbook_Open() MsgBox ("start") Workbooks.Open ("book2.xls") End Sub

@book2

Sub Workbook_Open() MsgBox ("NO2 Open!") Workbooks.Open ("book3.xls") End Sub

@book3

Sub Workbook_Open() MsgBox ("OK, done") End Sub

###試したこと

それぞれbook2のbook3呼び出し時に、ブレイクポイントで止めてprint Workbooks.Open ("book2.xls").Nameすると、「book1」が帰ってきます。

###補足情報(言語/FW/ツール等のバージョンなど)

Microsoft Visual Basic version 14.2
Mac OX Yosemite

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Windows7 Office2010では事象は再現せず、正しく連鎖的に開くことができました。
もしかしたらMac版特有のバグなのかもしれません。

代替案としてbook2はWorkbooks_Openではなく、独自のプロシージャを用意してBook1から呼び出すというのはどうでしょうか。これでやりたいことは実現できませんか。

@Book1

lang

1Sub Workbook_Open() 2 MsgBox "start" 3 Dim wb2 As Workbook 4 Workbooks.Open("C:\book2.xlsm").wbOpen 5End Sub

@Book2

lang

1Sub wbOpen() 2 MsgBox "NO2 Open!" 3 Workbooks.Open("C:\book3.xlsm").wbOpen 4End Sub

@Book3

lang

1Sub wbOpen() 2 MsgBox "OK, done" 3End Sub

投稿2016/04/06 17:27

thom.jp

総合スコア686

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sokha

2016/04/07 00:20

なんと解答いただけるとは思いませんでした。 そしてありがとうございます。windowsだと、いけるのですね。 それが分かっただけでもだいぶ違います。ありがとうございます。 代替案試して見ます。 terratailに初めて感謝します。ありがとうございます。
sokha

2016/04/07 02:13 編集

こちらで回答いただいた通り、独自のプロシージャを呼び出すことできちんと呼び出すことができました。 ありがとうございます。 こちらをベストアンサーとして、解決としたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問