長々と書いて申し訳ありませんが、困っています。
使用環境はWindows 2000です。開発環境というかexcel2000のVBAでコーディングしています。
で問題点が2点ありまして、
(1)EnumWindowsの所で止まるのですが、AddressOf演算子はexcel2000でも使えますよね。
コンパイルエラー Sub、Function、または Property が必要です というエラーで止まります。
何か使用方法が間違っていますでしょうか?
(2)テキストボックスを2つ用意してあるので、それを引数としてtelnetでつなぐパソコンを
選べるようにしたいのですが引数でうまく渡せません(現状はコメントアウトしている部分です)。
Private Sub CommandButton1_Click()
box1 = TextBox1
box2 = TextBox2
'ipnum = "telnet xxx.xxx."box1"."box2
'待ち時間処理用の時刻の変数
newHour = Hour(Now())
newMinute = Minute(Now())
Shell "cmd.exe"
lRet = Shell("C:\WINNT\system32\cmd.exe", vbNormalFocus)
newSecond = Second(Now()) + 5
waitTime = TimeSerial(newHour, newMinute, newSecond)
Application.Wait waitTime
Call EnumWindows(AddressOf Rekkyo, 0)
lRet = FindWindow(vbNullString, "C:\WINDOWS\system32\cmd.exe")
Call SendMessage(lRet, WM_SYSCOMMAND, WM_MAXIMIZE, ByVal 0&)
Call PostMessageStrings("telnet xxx.xxx.xxx.xxx")
'Call PostMessageStrings(ipnum)
Call PostMessageStrings("xxx.bat")
Call PostMessageStrings("exit")
Call PostMessageStrings("exit")
End Sub
Public Function PostMessageStrings(strPost As String)
Dim i As Integer
'1文字ずつ分解して送信
For i = 1 To Len(strPost)
Call PostMessage(lRet, &H102, Asc(Mid(strPost, i, 1)), 0)
Next
'送信後に改行コードを送信
Call PostMessage(lRet, &H102, 13, 0)
End Function
標準モジュールに、こんな感じでAPI関数を記述してあります。
他のAPIも記述してありますが、割愛してあります。
'ウィンドウのハンドルの取得
Declare Function EnumWindows Lib "user32" (ByVal lpEnumFunc As Long, ByVal lParam As Long) As Long
誰か教えてください。よろしくお願いします。
No.4ベストアンサー
- 回答日時:
>デバックモードで値を見ているとlRetに何も入っていないのでここが悪いと思うのですが
FindWindow() の戻り値が、でしょうか?
それとも、PostMessageStrings() の中で、でしょうか?
よく見てみると lRet がどこで宣言されているのかわかりませんね。
Sub CommandButton1_Click() の中で
Dim lRet As Long
と宣言しているのでしょうか?
そうだとすると、PostMessageStrings() の中の lRet は PostMessageStrings() の中で暗黙に宣言されたものとみなされてしまうので、PostMessageStrings() の中 lRet は 0 になってしまいます。
(General) の (Declarations) で
Private lRet As Long
と宣言するか、PostMessageString() にウィンドウハンドルの引数を追加する必要があります。
だいたい、↓こんな感じですね。
(テキストボックスから取得するところはご自分で適当に直してください。)
(General) - (Declarations)
Private Declare Function FindWindowA Lib "user32" (ByVal cnm As String, ByVal cap As String) As Long
Private Declare Function PostMessage Lib "user32.dll" Alias "PostMessageA" (ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
Private Declare Sub Sleep Lib "kernel32.dll" (ByVal dwMillsecounds As Long)
Private Const WM_CHAR = &H102
Private Sub CommandButton1_Click()
Dim lngRet As Long
Dim hWnd As Long
lngRet = Shell("cmd.exe", vbNormalFocus)
Sleep 100
hWnd = FindWindowA(vbNullString, "C:\WINDOWS\system32\cmd.exe")
SendString hWnd, "telnet xxx.xxx.xxx.xxx"
End Sub
Private Sub SendString(ByVal hWnd As Long, ByVal s As String)
Dim i As Integer
Dim c As String
For i = 1 To Len(s)
c = Mid(s, i, 1)
PostMessage hWnd, WM_CHAR, Asc(c), 0
Sleep 10
Next i
PostMessage hWnd, WM_CHAR, Asc(vbCrLf), 0
End Sub
ありがとうございます。
tsukasa-12rさんのソースを参考にしながら修正を加えたら動くようになりました。
telnetも無事に出来てしたい作業が出来るところまで確認できました。
ただ別の問題点も発生しまして、たまにコマンドプロンプトに渡す時に
telnet xxx.123.456.789
の部分が
telnet xxx.123.45.78 や telnet xxx.123.45.789
になってしまうバグが発生します。
どうも telnet xxx.123.455.788 みたいに同じ数字のときの起こる
ようでして、困っています。
ただ自分のソースで言うところのipnumの変数の値をメッセージボックスで
表示させたところ、バグになる時でも
telnet xxx.123.456.789
と表示されます。
後、困っているというか結果の確認が出きないので
テルネット先で実行後にerrorlevelとかに入る値をどうにか取得できませんか?
注文が多くてすいません。自分でも調べてみます。
No.5
- 回答日時:
>telnet xxx.123.456.789
>の部分が
>telnet xxx.123.45.78 や telnet xxx.123.45.789
>になってしまうバグが発生します。
ANo.4 のソースには記述していましたが(説明はしていませんでしたが)、PostMessage() の呼出しごとに Sleep ( または wait ) を入れると回避できるようです。
この回答への補足
回答ありがとうございます。
やってみたいのですが、休日なので火曜日まで試せないのが残念です。
プログラムを途中まで止めておかないと、入力がうまくいかないのは分りますが、
telnet xxx.123.45.789
みたいになるパターンも同じ理由なんですか?
最後の文字とかが落ちてると納得いくのですが、途中が落ちてると理屈が合わない気がします。
何にせよ、火曜日になったら試してみます。
ありがとうございました。
ありがとうございます。
確かに
telnet xxx.123.45.78
みたいなバグが出なくなりました。
ただ、プログラムの待ち状態が長いと非常に使い勝手が悪いので、スリープ時間をうまく調整してみます。
色々とありがとうございました。
No.3
- 回答日時:
>最初に書いたようにEnumWindowsを標準モジュールに記述してありますが、そことは別に必要なんでしょうか?
EnumWindows() の宣言をしている標準モジュールに Function Rekkyo() がある、ということですか?
というか、もしかして、Function Rekkyo() をどこにも作成していないのではないですか?
>ただの引数としてcmd.exeを渡すものだと思っていました。
というところから、Function Rekkyo() を作成していないのではないかという気がしてきました。
EnumWindows( Address CallBackProc ) というのは、OS に、「 Window を列挙してね。そして、列挙した Window ごとに、CallBackProc にウィンドウハンドルを渡して呼び出してね。」
というお願いをするというものです。CallBackProc ( 名称は別に何でも構わない ) はこちらで用意しておきます。が、
Public Function CallBackProc(ByVal Handle As Long) As Boolean
の形式にしなければなりません。
というか、FindWindow() でウィンドウハンドルが取得できるのであれば、EnumWindows() は使用する必要はないんじゃないでしょうか。
この回答への補足
度々の解答ありがとうございます。
ご指摘の通り、EnumWindowsは関係なくてFindWindowの所でエラーが出てうまくいってなかったようです。
Function Rekkyo() は作成していなかったのですが、ウィンドウを列挙する必要性はないので作成していません。
問題はFindWindow() でウィンドウハンドルが取得できず、コマンドプロンプトに文字列がうまく渡せません。
標準モジュールにFindWindowは以下のように宣言してあります。
Declare Function FindWindow Lib "user32.dll" Alias "FindWindowA" _
(ByVal lpClassName As String, ByVal lpWindowName As String) As Long
デバックモードで値を見ているとlRetに何も入っていないのでここが悪いと思うのですが、どんな風に変えればいいんでしょうか?
lRetをlongで宣言していたのが間違えたのかと思って、string等と色々と変えてみたのですがうまくいきませんでした。
stringだと数字が入るのにlongだと""(NULL値?)でした。
lRetに渡す所もcmd.exeにしたり、C:\WINNT\system32\cmd.exeにしたり色々といじっているのですが、値が渡せません。
FindWindowについても教えていただけるとうれしいです。
No.2
- 回答日時:
では(2)の方を。
。。Private Sub CommandButton1_Click()
Dim ipnum As String
ipnum = "telnet xxx.xxx." & TextBox1.Text & "." & TextBox2.Text
MsgBox ipnum
変数の型が分からなかったので勝手にStringとしました。
「.Text」で取れます。
この回答への補足
こちらにも早々と解答を下さって、ありがとうございます。
既に帰宅してしまってすぐには試せないのですが、試してみたいことこの上ないです。
で、この形にすると変数にうまくまとめられるんですね。
FunctionにはStringで渡しているので、このまま使えそうです。
明日、早速試してみます。ありがとうございました。
試してみたところ、うまくいきました。
ありがとうございます。
ただ、(1)の方がうまくいかないままなので、全体としては困ったままです。
No.1
- 回答日時:
とりあえず (1) の方だけですが、
Call EnumWindows(AddressOf Rekkyo, 0)
で指定する Function Rekkyo ですが、なぜか標準モジュールにおかなければならないようです。
(標準モジュールは VBA の画面でメニューの「挿入」からできます。)
この回答への補足
早速の解答ありがとうございます。
最初に書いたようにEnumWindowsを標準モジュールに記述してありますが、そことは別に必要なんでしょうか?
AddressOf演算子をうまく理解していないのか、ただの引数としてcmd.exeを渡すものだと思っていました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【お題】NEW演歌
【大喜利】 若い人に向けたことは分かるけど、それはちょっと寄せ過ぎて変になってないか?と思った演歌の歌詞
-
チョコミントアイス
得意ですか?不得意ですか?できれば理由も教えてください。
-
「覚え間違い」を教えてください!
私はかなり長いこと「大団円」ということばを、たくさんの団員が祝ってくれるイメージで「大円団」だと間違えて覚えていました。
-
昨日見た夢を教えて下さい
たまにすごいドラマチックな夢見ること、ありませんか? 起きてからも妙に記憶に残っているような、そんな夢。
-
好きな和訳タイトルを教えてください
洋書・洋画の素敵な和訳タイトルをたくさん知りたいです!【例】 『Wuthering Heights』→『嵐が丘』
-
[WSH|JS|VB] telnetコマンドの標準出力を受け取りたい
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ランキング
-
VBでグローバル変数を宣言するには
-
Excel VBAで、ユーザーフォーム...
-
Excel VBAでリンク切れをチェッ...
-
VBAで別モジュールへの変数の受...
-
vba 標準モジュールインポート...
-
エクセルVBAでシートモジュール...
-
Form間の値の渡し方
-
モジュールとクラスの違いって...
-
Excel VBA 『Call』で呼び出す...
-
グラフのX,Y座標を取得したい
-
モジュールとは何ですか
-
本当にPublicな変数(配列で)
-
VBAで旧字体を異字体に一括で変...
-
シートモジュールで使う変数を...
-
Excel VBA 標準モジュールの整...
-
Workbook.BeforeSave イベント...
-
VBA This Workbookモジュール...
-
VHDLにおける「generic」について
-
ユーザー定義関数に#NAME?が返...
-
VBのフォームモジュールと標準...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
Excel VBAで、ユーザーフォーム...
-
ユーザー定義関数に#NAME?が返...
-
Excel VBA 『Call』で呼び出す...
-
エクセルVBAでシートモジュール...
-
VBAで別モジュールへの変数の受...
-
モジュールの最大数はいくつな...
-
VBでグローバル変数を宣言するには
-
グラフのX,Y座標を取得したい
-
VBA This Workbookモジュール...
-
モジュールとクラスの違いって...
-
【vba】フォームに書いてあ...
-
VBAで旧字体を異字体に一括で変...
-
vba userFormのSubを標準モジュ...
-
ベースモジュールって?
-
標準モジュールを削除したい。(...
-
Access VBA標準モジュールにつ...
-
Form間の値の渡し方
-
VBAProjectのモジュ...
-
'Range'メソッドは失敗しました
おすすめ情報