ここから本文です

Excel 2010 VBAで質問です。マクロで通常使うプリンタに設定されているプリンタを...

tmc********さん

2012/5/2313:07:32

Excel 2010 VBAで質問です。マクロで通常使うプリンタに設定されているプリンタを取得したいのですが可能でしょうか。

ActivePrinterでは、現在使用しているプリンタ(エクセル→印刷で設定したプリンタ)で、通常使うプリンタではありません。
VBや.NETだとSystem.Drawing.Printing.PrintDcumentより取得できそうでしたが、VBAではだめでした。

閲覧数:
3,038
回答数:
1
お礼:
250枚

違反報告

ベストアンサーに選ばれた回答

por********さん

2012/5/2317:37:41

こんにちは。
VBAで、WMIを使った場合です。
Dim myComputer As String
Dim oWMIService As Variant
myComputer = "."
Set oWMIService = CreateObject("winmgmts:{impersonationLevel=impersonate}!\\" & myComputer & "\root\cimv2")
Dim ps As Variant
Set ps = oWMIService.ExecQuery("Select * from Win32_Printer")
Dim oPrinter As Object
For Each oPrinter In ps
'通常使うプリンターを取得
If oPrinter.Default Then
Debug.Print oPrinter.Caption
End If
Next
これで、debug.printしたもしたものが、OSの「通常使うプリンタ」です。エクセルで切り替えなどをしても、影響されないです
(application.ActivePrinterは、印刷画面で切り替えたら、変化します)

この質問は投票によってベストアンサーに選ばれました!

みんなで作る知恵袋 悩みや疑問、なんでも気軽にきいちゃおう!

Q&Aをキーワードで検索:

Yahoo! JAPANは、回答に記載された内容の信ぴょう性、正確性を保証しておりません。
お客様自身の責任と判断で、ご利用ください。
本文はここまでです このページの先頭へ

「追加する」ボタンを押してください。

閉じる

※知恵コレクションに追加された質問は選択されたID/ニックネームのMy知恵袋で確認できます。

不適切な投稿でないことを報告しました。

閉じる