teratail header banner
teratail header banner
質問するログイン新規登録

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

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

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

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1779閲覧

python pywin32でディスパッチしたCOMのID確認方法

shiri

総合スコア13

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2022/02/27 16:41

0

0

import win32com.client COM = win32com.client.Dispatch('Excel.Application')

(上記は例ですが)
・取得したCOMのIDを確認方法をご教授願えませんでしょうか?
OLEVIEWとか外部ツールを使うのではなくて、プログラムとして取得するやり方を知りたいのです

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

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

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

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

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

cx20

2022/02/27 17:40

取得したいCOMのIDというのはCLSIDのことでしょうか?
guest

回答1

0

ベストアンサー

もっと簡単な方法があるかもしれませんが、
ProgID から CLSID の取得は CLSIDFromProgID という Win32 API を用いることで取得可能です。

python

1from ctypes import * 2 3BYTE, WORD, DWORD = c_ubyte, c_ushort, c_ulong 4CLSIDFromProgID = oledll.ole32.CLSIDFromProgID 5 6class GUID(Structure): 7 _fields_ = [("Data1", DWORD), ("Data2", WORD), ("Data3", WORD), ("Data4", BYTE * 8)] 8 9progid = "Excel.Application" 10guid = GUID() 11progid = progid 12CLSIDFromProgID(progid, byref(guid)) 13 14print("ProgID : [" + progid + "]") 15print("CLSID : [{%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x}]" % 16 ( 17 guid.Data1, 18 guid.Data2, 19 guid.Data3, 20 guid.Data4[0], 21 guid.Data4[1], 22 guid.Data4[2], 23 guid.Data4[3], 24 guid.Data4[4], 25 guid.Data4[5], 26 guid.Data4[6], 27 guid.Data4[7] 28 ) 29)

■ 実行結果

ProgID : [Excel.Application] CLSID : [{00024500-0000-0000-c000-000000000046}]

■ 検証結果
イメージ説明

<参考>
■ How to use IFileOperation from ctypes
https://stackoverflow.com/questions/62065891/how-to-use-ifileoperation-from-ctypes

投稿2022/02/27 18:46

cx20

総合スコア4700

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

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

shiri

2022/02/28 07:39

ご教授ありがとうございます。こちらの意図がうまく伝わっていないようで申し訳ございません。 やりたいのが'Excel.Application'というワードを例としてとったのですが、今は このワードが上位から知らされてなくてCOMオブジェクトだけインスタンスとして渡されている状態なのです。 で、別のプロセスからも使いたいのですがインスタンスからProgIDやCLSIDを取れないかというのを期待しています
shiri

2022/02/28 11:46

ありがとうございます。うまくいきました(メソッド云々が呼べるかはまた引き続きがんばります)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

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

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

質問する

関連した質問