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

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

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

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

Q&A

解決済

1回答

7607閲覧

EXCEL VBAでプロセスIDを取得したい

MagiSystem

総合スコア10

VBA

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

0グッド

0クリップ

投稿2022/12/28 04:38

実現したいこと

EXCEL VBAで起動したEXCELファイルのプロセスIDを取得したいです

EXCEL VBAマクロファイルから他のExcelファイルを
作成、保存、起動、終了等を行っているのですが、
終了しているつもりがプロセスが残ることがあり、
どのファイルのプロセスが残っているのかを確認したいため、
起動中の全てのExcelファイルのプロセスIDをVBA上で取得したいです。
どなたかご教授お願い致します。

発生している問題・エラーメッセージ

VB.NETではGetProcessesByNameを用いて
Dim ps As System.Diagnostics.Process() = _
System.Diagnostics.Process.GetProcessesByName("excel.exe")
のようにすればできる記事があったので、
EXCEL VBAで同様に行ってみましたが、
Dim ps As System.Diagnostics.Process() = _
の部分の(でエラーになり、やり方がわかりません。

補足情報(ツールのバージョンなど)

Windows10
Microsoft Excel for Office365

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

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

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

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

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

guest

回答1

0

ベストアンサー

質問への回答としては、下記のコードで表示されますが、普通は1プロセスで複数ファイルを開いているだろうし、複数プロセスを起動した場合も、どれがどれかをどうやって区別するのでしょうか?

VBA

1For Each proc In GetObject("winmgmts:\\").ExecQuery("select * from Win32_Process where Name='Excel.exe'") 2 Debug.Print proc.processid, proc.commandline 3Next

投稿2022/12/28 06:15

otn

総合スコア86277

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

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

MagiSystem

2022/12/28 06:39

ご回答ありがとうございます。 ご指摘頂き、下記を確認して理解しました。 test01.xls、test02.xls、test03.xlsのファイルを起動して、リソースモニターのCPUタブを選択。 関連付けられたハンドルで test0 フィルタをしたところ、全て同一のPIDでした。 別のアプローチで考えてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問