こんにちは。
Excel VBAより、ExecuteExcel4Macroを実行して、
外部のExcelファイルの、名前(店名、月度)を定義したセルの値を取得したいと思っています。
店名:文字列型
月度:Date型
そこで、ExecuteExcel4Macro()を実行し、以下のような処理を加えました。
------------------------------------------------------------------------------------
dim 店名 as Variant, 月度 as Variant
If 外部マクロ実行("'c:\[test.xls]出勤簿'!店名", 店名) = False Or _
外部マクロ実行("'c:\[test.xls]出勤簿'!月度", 月度) = False Then
MsgBox "取得失敗", vbExclamation
End
End If
Public Function 外部マクロ実行(com As String, ByRef result As Variant) As Boolean
On Error GoTo erron3
result = ExecuteExcel4Macro(com)
On Error GoTo 0
外部マクロ実行 = True
Exit Function
erron3:
外部マクロ実行 = False
End Function
------------------------------------------------------------------------------------
これを実行したところ、「月度」の値は取得できるのですが、
「店名」の値には「エラー 2042」という値が入ります。
※dirname, filenameは正しい値が入っています。
※シート「出勤簿」および「月度」「店名」のセル名の定義も存在します。
test.xlsを開いてるときは、上記の現象は起こらず、
「店名」の値は正常に取得できます。
また、試しに、test.xlsを開き、
Worksheets("出勤簿").Range("店名")を実行すると、正常な値が取得できました。
まとめると、
・閉じたブックの、あるシートにある、セルに定義された名前を指定して
・ExecuteExcel4Macroで、文字列が入っている値を取得しようとした時、
・正常に値が取得できない
という現象に遭遇しています。
3日ほど調べているのですが、どうしても原因が分かりません。
解決策をお持ちの方、いらっしゃいましたらアドバイスを頂けると助かります。
環境:WindowsXP Pro SP3
Excel 2003 (11.5612.5606)
以上、よろしくお願いいたします。
No.1ベストアンサー
- 回答日時:
'-------------------------------------------------
Sub Test()
Dim 店名
Dim 月度
店名 = 外部マクロ実行("'C:\[test.xls]出勤簿'!店名")
月度 = 外部マクロ実行("'C:\[test.xls]出勤簿'!月度")
If 店名 = 0 Or 月度 = 0 Then
MsgBox "取得失敗", vbExclamation
Else
MsgBox 店名 & " @ " & Format(月度, "yyyy/m/d")
End If
End Sub
'-----------------------------------------------
Function 外部マクロ実行(com As String)
外部マクロ実行 = ExecuteExcel4Macro(com)
End Function
'-----------------------------------------------
●ただ今回の場合は、Functionは無しでもいいような。。。
'----------------------------------------------
Sub Test555()
Dim 店名
Dim 月度
店名 = ExecuteExcel4Macro("'C:\[test.xls]出勤簿'!店名")
月度 = ExecuteExcel4Macro("'C:\[test.xls]出勤簿'!月度")
If 店名 = 0 Or 月度 = 0 Then
MsgBox "取得失敗", vbExclamation
Else
MsgBox 店名 & " @ " & Format(月度, "yyyy/m/d")
End If
End Sub
'----------------------------------------------------
以上。
No.2
- 回答日時:
こんにちは。
ExecuteExcel4Macro というスタイルは、直接、マクロ関数を取る以外は、追いかけないほうがよいかもしれませんが、そのコード自体は間違いありません。
>「エラー 2042」という値が入ります。
という意味は、「#N/A 」の戻り値です。
だから、そのエラー値は、数式側だけの問題です。数式を調べないといけません。
"'c:\[test.xls]出勤簿'!店名"
私としては、その書き方は、一見良いのですが、実際、ルートに置くわけではないでしょうから、失敗しやすいです。
これは、目的のファイルが開いていない状態で扱うときですが、実務上では、ファイルが開いていなければ、開けて、Evaluate で取るというのが、一般的な書き方です。そうでなければ、DAOやADOを使って開くというスタイルになります。
全体的に、Excelマクロとしては変則的なコードだと思います。
今回の場合は、ユーザー定義関数側では、参照渡しは、あまり良いとは思いません。実行時エラーと両方を取ろうとしたので、Boolean値のユーザー定義関数自体を戻り値にしたのだと思いますが、この種のものは、実行時エラーが発生するのは、コードの自体の間違いか、ファイルが存在しない間違いですから、Dir 関数などの回避の仕方はあると思います。単に、数式の戻り値を、ユーザー定義関数側に返すだけで十分な気がします。
なお、そのコードは「外部マクロ実行」ではありません。
'----------------------------------------
Dim 店名 As Variant, 月度 As Variant
Dim nShiki1 As String
Dim nShiki2 As String
Const nPATH = "'C:\Documents and Settings\[UserName]\My Documents\"
Const nWBNAME = "test.xls"
Const nSHNAME = "出席簿"
Const nADDRESS1 = "店名" '名前登録はそのまま、アドレスなら、R1C1方式
Const nADDRESS2 = "月度"
nShiki1 = "[" & nWBNAME & "]" & nSHNAME & "!" & nADDRESS1
店名 = Evaluate(nShiki1) 'ファイルが開いているかチェックする
If IsError(店名) Then
nShiki1 = nPATH & "[" & nWBNAME & "]" & nSHNAME & "'!" & nADDRESS1
nShiki2 = nPATH & "[" & nWBNAME & "]" & nSHNAME & "'!" & nADDRESS2
'Debug.Print nShiki ''数式の内容チェック
If 外部マクロ実行(nShiki1, 店名) = False Or _
外部マクロ実行(nShiki2, 月度) = False Then
MsgBox "取得失敗", vbExclamation
Exit Sub
End If
Else
nShiki2 = "[" & nWBNAME & "]" & nSHNAME & "!" & nADDRESS2
月度 = Evaluate(nShiki2)
End If
End Sub
'-----------------------------------
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2022/10/13 08:41
- Visual Basic(VBA) エクセルのマクロとシートの保護について教えてください。 1 2022/10/18 08:36
- Visual Basic(VBA) 貼り付けた値が消えていく 以下はソースファイルの2番目のシートのB6から最終行を取得 ターゲットファ 2 2023/07/27 12:23
- PowerPoint(パワーポイント) エクセルのマクロについて教えてください。 1 2023/01/20 14:36
- Visual Basic(VBA) エクセルのマクロを使ってメールを送る方法について教えてください 2 2022/03/29 01:36
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/15 15:12
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/09 10:33
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
このQ&Aを見た人はこんなQ&Aも見ています
-
好きなおでんの具材ドラフト会議しましょう
肌寒くなってきて、温かい食べ物がおいしい季節になってきましたね。 みなさんはおでんの具材でひとつ選ぶなら何にしますか? 1番好きなおでんの具材を教えてください。
-
チョコミントアイス
得意ですか?不得意ですか?できれば理由も教えてください。
-
メモのコツを教えてください!
メモを取るのが苦手です。 急いでメモすると内容がごちゃごちゃになってしまったり、ひどいときには全く読めない時もあります。
-
牛、豚、鶏、どれか一つ食べられなくなるとしたら?
牛肉、豚肉、鶏肉のうち、どれか一種類をこの先一生食べられなくなるとしたらどれを我慢しますか?
-
【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
【お題】 ・急に朝起こしてきた母親に言われた一言とは?
-
VBA ExecuteExcel4Macro 型が一致しません
Excel(エクセル)
-
Excel VBAのApplication.ExecuteExcel4Macro
Access(アクセス)
-
sumproductの計算式で「エラー2015」(ローカルウィンドウにて)が表示(Excel2007、2003)
その他(Microsoft Office)
-
-
4
ファイルを閉じたままの外部参照で最終行の行数取得
Visual Basic(VBA)
-
5
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
6
VBScriptによるExecuteExcel4Macroの使い方について
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
勃起する時って痛いんですか? ...
-
これって喉仏ですか? 私は女性...
-
精液の落とし方を教えてください
-
2つの数値のうち、数値が小さい...
-
EXCELで式からグラフを描くには?
-
エクセル指定した範囲からラン...
-
白血球が多いとどんな心配があ...
-
検便についてです。 便は取れた...
-
イタリアから帰国する際、肉製...
-
リンク先のファイルを開かなく...
-
至急!尿検査前日にオナニーし...
-
EXCELで条件付き書式で空白セル...
-
風俗店へ行く前のご飯
-
【Excelで「正弦波」のグラフを...
-
エクセルのラベルの値(文字列...
-
エクセルで数式の答えを数値と...
-
VLOOKUP関数を使用時、検索する...
-
小数点以下を繰り上げたものを...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
首吊りどこ締めるの
-
彼女のことが好きすぎて彼女の...
-
白血球が多いとどんな心配があ...
-
検便についてです。 便は取れた...
-
精液の落とし方を教えてください
-
勃起する時って痛いんですか? ...
-
2つの数値のうち、数値が小さい...
-
エクセル指定した範囲からラン...
-
エクセルで数式の答えを数値と...
-
これって喉仏ですか? 私は女性...
-
小数点以下を繰り上げたものを...
-
EXCELで条件付き書式で空白セル...
-
EXCELで式からグラフを描くには?
-
イタリアから帰国する際、肉製...
-
エクセルのラベルの値(文字列...
-
Excel 0目標に対して数字があ...
-
ある範囲のセルから任意の値を...
-
風俗店へ行く前のご飯
-
リンク先のファイルを開かなく...
-
甲状腺が腫れているが血液検査...
おすすめ情報