VBScriptにおいて、Win32API関数のGetWindowTitleをExcel経由で使用したいと考えております。
そこで、ネットで検索したところ、VBScriptからAPI関数の指定の引数の値を取り出す方法がありました。
https://blogs.yahoo.co.jp/nobuyuki_tsukasa/53646 …
この情報を基に、最前面画面のウィンドウタイトルを取得する下記サンプルコードを作成して実行したたところ、下段から3行目のところで、下記のエラーが出てしまいます。
コード:
Option Explicit
Dim AppExcel
Dim myHwnd
Dim myFixCaption
Dim myCaption
Dim strMacro
Dim ret
Set AppExcel = CreateObject("Excel.Application")
'最前面のウィンドウのウィンドウハンドルを取得
strMacro = "CALL('user32', 'GetForegroundWindow', 'J'" & ")"
strMacro = Replace(strMacro, "'", """")
myHwnd = AppExcel.ExecuteExcel4Macro(strMacro)
'タイトルの取得
'GetWindowText myHwnd, myFixCaption, Len(myFixCaption)
myFixCaption = Space(255)
strMacro = "CALL('user32', 'GetWindowText', '2JCJ', " & CStr(myHwnd) & ", '" & myFixCaption & "', " & Len(myFixCaption) & ")"
strMacro = Replace(strMacro, "'", """")
myFixCaption = AppExcel.ExecuteExcel4Macro(strMacro) '←ここで下記エラー発生
myCaption = Left(myFixCaption, InStr(myFixCaption, vbNullChar) - 1)
Set AppExcel = Nothing
エラー内容:
Application クラスの ExecuteExcel4Macro プロパティを取得できません。
環境:
OS;Windows10
Excel;Excel2013
どこがまずいのか、教えて下さい。
No.1ベストアンサー
- 回答日時:
こんばんは。
引用先のブログは、開発を投げたものてしょうから、こちらに振っても同じになるには違いないでしょう。はっきりとどこがということがわかりませんし、どこを直しても、このままでは通らないです。ExecuteExcel4Macroの中の数式のパラメータに、null文字が使えないのかとも思いました。数式のカッコ閉じる、が認識しないのです。
"CALL('user32', 'GetWindowText', '2JCJ', " & CStr(myHwnd) & ", '" & myFixCaption & "', " & Len(myFixCaption) & ")"
それと、
myFixCaption = Space(255) -> myCaption = Left(myFixCaption, InStr(myFixCaption, vbNullChar) - 1) これでは、整合性が取れませんよね。
myFixCaption は、 String(255, Chr(0)) だとは思うのですが、それを入れてしまうと、こんどは、数式のカッコが閉じなくなってしまいます。
試しに、DynamicWrapper なら、かろうじて取得できました。DynamicWrapper は、イントールというか、最初に、簡単な regsvr32.exe のレジストレーションが必要になってしまいますので、好まれないとは思いますが。
'-----DynamicWrapper ---
'サンプル
Dim objDynaWrap
Dim hWnd
Dim buf1
Dim myCap
Set objDynaWrap = CreateObject("DynamicWrapper")
objDynaWrap.Register "USER32.DLL", "GetForegroundWindow" ,"r=l" , "f=s"
objDynaWrap.Register "USER32.DLL", "GetWindowText", "i=lrl","r=l", "f=s"
buf1 =Space(20)
buf1 =String(20,Chr(0)) '30ではダメでした。
hWnd = objDynaWrap.GetForegroundWindow()
ret =objDynaWrap.GetWindowText( hWnd, buf1, Len(buf1))
myCap = Replace(buf1,Chr(0),"")
'myCap = Left(buf1,InStr(buf1,Chr(0))-1)
WScript.Echo myCap
Set objDynaWrap = Nothing
'----------------------------
かろうじて取れると書いたのは、なんとなく、このプログラムには、その作り方そのものに論理的な矛盾があるような気がしたからです。一番上のアプリのタイトルを取るけれども、これが、単独で動かしたら自分自身(VBSファイル)である可能性が高いし、そうでなく、他のプログラムから行っても、そのためのアクティベートしてしまったアプリになるわけです。なお、"i=lrl" のパラメータは合っているかわかりません。
p.s. Excelのバージョンの2013以降は、私の記憶では、オートメーションとして別起動しませんから、あえてExcelを使おうとしても、本体を使うのと同じになってしまうはずです。完全な独立プログラム・アプリを作るなら、Excelは使わないほうが良いのかもしれませんね。
WindFaller様
こんばんわ。
新年早々ご回答頂きまして、ありがとうございました。
ご指摘は非常に参考になりました。
API関数の使い方もわからずWebで検索しながら作ってみたものです。GetWindowText関数は、所定の長さの文字列を用意して置くと、呼出し後取得結果の文字列の最後にNull文字が付加されて返されるものと解していました。
いずれにしても、ExcecuteExcel4Macroでは、実現が難しそうなので、アドバイス頂いた方法等も参考にさせて頂き検討して行きたいと考えています。
なお、目的はVBScriptで表示されている画面の一覧を取得することです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ちょっと先の未来クイズ第2問
9月9日(月)に発表される「第3回子どもマネー川柳」に入賞する川柳を考えてこちらに投稿してください。
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
GetWindowText、GetActiveWindowについて
Visual Basic(VBA)
-
VBSでuser32.dll(Win32API)を使用する方法を教えてください。
Visual Basic(VBA)
-
Excel VBAのApplication.ExecuteExcel4Macro
Access(アクセス)
-
-
4
VBAでのExecuteExcel4Macroの値取得でエラー
Excel(エクセル)
-
5
VBスクリプト---アプリの終了について
その他(プログラミング・Web制作)
-
6
Excel VBA ExecuteExcel4Macroについて
その他(Microsoft Office)
-
7
VBScriptでコマンドプロンプトウィンドウを開いたままにしたいです
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
python エラー
-
エクセルのエラーメッセージ「4...
-
Excelのエラーで困ってます。
-
Arduinoに関する質問
-
デバッグ中のエラーのことで教...
-
ヘッダファイルでのFILE型引数...
-
Visual Studioのstrcpy_sについて
-
fortranでプログラムを実行する...
-
適切な変換関数が存在しない???
-
C++でscanfは使えない?
-
vbaでのerror"オーバーフロー"
-
レコードセットをcloseする所で...
-
VC++でboolがエラーになる
-
Excel VBAにて特定のサイトから...
-
ビルド失敗 指定されたファイ...
-
VisualStudio2010 VC++ エラー
-
LPCWSTRとchar
-
arduinoのエラーメッセージ
-
global.asaについて
-
入れ子になっている構造体配列...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
python エラー
-
エクセルのエラーメッセージ「4...
-
Excelのエラーで困ってます。
-
fortranでプログラムを実行する...
-
バッチからsqlplusの接続エラー...
-
適切な変換関数が存在しない???
-
VB2008で定数に色の設定をした...
-
HEWを使用しているのですが、こ...
-
sys/time.hのインクルードがで...
-
BC30002: 型 'ListItem' が定義...
-
Handlesについて
-
Visual Studioのstrcpy_sについて
-
RightとLeft関数のライブ...
-
error C3867 関数呼び出しには...
-
デバッグ中のエラーのことで教...
-
コンパイルできません。
-
multiple definitionというエラー
-
ビルド失敗 指定されたファイ...
-
レコードセットをcloseする所で...
-
左側がクラス、構造体、共用体...
おすすめ情報