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

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

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

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

Q&A

解決済

1回答

355閲覧

VBAのAPIについて解説をお願いします。

King_of_Flies

総合スコア382

VBA

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

0グッド

0クリップ

投稿2017/10/19 04:49

お疲れ様です。

下記URLからダウンロードできるファイルのコードを一部抜粋

http://www.asahi-net.or.jp/~ef2o-inue/vba_o/sub05_100_100.html

vba

1' ウィンドウハンドル取得API 2Private Declare Function FindWindow Lib "user32" _ 3 Alias "FindWindowA" _ 4 (ByVal lpClassName As String, _ 5 ByVal lpWindowName As String) As Long

というプロシージャがあるのですが、
Declare とLibとAliasの説明をお願いしたいです。

  • Declare

http://www.officetanaka.net/excel/vba/statement/Declare.htm

ダイナミックリンクライブラリ(DLL)の外部プロシージャへの参照を宣言します。

とありますが、つまり今回はuser32というDLLのFindWindowAというプロシージャを参照しているということで良いのでしょうか?

また、引数として渡しているlpClassNameとlpWindowNameについて、
ダウンロードファイルのソースコードを見る限りでは、
lpClassNameおよびlpWindowNameに値をセットしていないように思うのですが、どうやって引数を与えているのでしょうか。

lpClassNameとlpWindowNameを引数として与えると、Long型の値が戻り値として返ってくるのはわかるのですが・・・。

解説お願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ダウンロード(「日付入力」のクラス)

上記のリンク先からダウンロードできるファイルのことですか。

FindWindow API を使用しているコードは、下記の2行だと思いますが、ちゃんと引数を設定しています。どのコードを見て、引数を設定していないと判断したのでしょうか。

VB

1lnghWnd_Form = FindWindow(strThunder, mctlForm.Caption) 2 3lnghWnd_Excel = FindWindow("XLMAIN", Application.Caption)

これ以外の部分は、現状のご理解で間違いないと思います。

投稿2017/10/19 05:47

hatena19

総合スコア33715

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

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

King_of_Flies

2017/10/19 05:54

lnghWnd_Form = FindWindow(strThunder, mctlForm.Caption) lnghWnd_Excel = FindWindow("XLMAIN", Application.Caption) で lpClassNameおよびlpWindowNameの値セットが行われるということでしょうか?
King_of_Flies

2017/10/19 05:56

すいません、理解しました。 私の認識誤りのようです。
King_of_Flies

2017/10/19 05:58

lpClassNameとlpWindowNameを引数として与えると、Long型の値が戻り値として返ってくるのはわかるのですが・・・。 ↓ lpClassNameとlpWindowName”に”引数として与えると、Long型の値が戻り値として返ってくるのはわかるのですが・・・。 ですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問