いつもお世話になります
今、皆様の投稿プログラムを使わせてもらい
アクティブブックの全シートをPDFにエクスポートしてから印刷してみました
その際、エクスポート時は OpenAfterPublish:=False によりPDFファイルの画面出力は
抑えられたのですが次の印刷後、起動されたAcrobatReaderDCの起動画面が残ってしまいます
そこで最後のステートメントを皆様の投稿サイトをいろいろ調べたのですが
よく分かりません
もし、起動されたAcrobatReaderDCの起動画面を終わらせるステートメントが
分かりましたら教えてください
Sub Macro5()
’...ファイル出力
ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _
"C:\Temp\sample1.pdf", Quality:=xlQualityStandard, _
IncludeDocProperties:=True, IgnorePrintAreas:=False, OpenAfterPublish:=False
'...印刷
Set w = CreateObject("WScript.Shell")
a = "c:\temp\sample1.pdf"
For i = 0 To 0
w.Run ("AcroRd32.exe /t " & Chr(34) & a & Chr(34))
Next
Set w = Nothing
End Sub
以上、よろしくお願い申し上げます
No.1ベストアンサー
- 回答日時:
こんにちは。
急いで考えてみました。実験的なコードですが、
Set w = Nothing
<--ここに入れてみました。※
End Sub
---------------
'モジュールの最上部へ
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Private Declare Function SendMessage Lib "user32.dll" Alias "SendMessageA" (ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByRef lParam As Any) As Long
Private Const WM_SYSCOMMAND As Long = &H112
Private Const SC_CLOSE As Long = &HF060&
---------------
'※コードの中途から
Dim hWnd As Long
Dim ret As Long
Dim cnt As Long
Do
hWnd = FindWindow("AcrobatSDIWindow", vbNullString)
DoEvents
cnt = cnt + 1
If cnt > 5000 Then
MsgBox "失敗しました。", vbCritical
Exit Sub
End If
Loop While hWnd = 0&
'' Debug.Print hWnd '検査用 不要です
Application.Wait Now + TimeSerial(0, 0, 5)
ret = SendMessage(hWnd, WM_SYSCOMMAND, SC_CLOSE, 0)
--------------------
もう少し、丹念に調べれば、コードは短くなるはずですが、Acrobat から印刷をかけた瞬間に、コマンドは利かなくなるようなので、以下のようなコードを入れました。5秒が最適なのかは分かりません。もっと短くしてもよいかもしれません。
Application.Wait Now + TimeSerial(0, 0, 5)
また、MsgBox は、あくまでも、試験用のために入れていますので、直接、Exit Sub で構いません。
他にも、winmgmts から、Process.Terminate で終わらせる方法もありますが、SendMessageのほうがメジャーだと思いました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセル2019でPDFファイル名に枝番号をつけたい。 アクティブワークシートを印刷した後の処理とし 4 2023/06/06 21:00
- Excel(エクセル) PDFファイルに日付を名前にして保存したい。 エクセル2019でワークシートに請求書のフォームを作り 2 2023/05/27 11:13
- Excel(エクセル) エクセルVBA、間違っているコード内容を正して頂けませんか? エクセルワークシートに納品書を作ったの 2 2023/08/02 21:13
- Excel(エクセル) このコードに追記事項の仕方を教えて下さい。 以下のコード内容に出てくる。セルH3が空白の場合、エラー 4 2023/08/03 00:22
- Excel(エクセル) エクセルVBA、ファイル名をセルの値で保存の方法を教えてください。 おそれいります。こちらで数々のエ 6 2023/06/30 22:17
- Visual Basic(VBA) ワイルドカード「*」を使うとうまくいかないマクロの添削をお願いします 3 2022/03/26 09:39
- Visual Basic(VBA) VBA★PDFをPDFアプリで印刷しようと思っていますが上手くゆきません 1 2022/06/06 22:04
- Visual Basic(VBA) エクセルのマクロを使ってメールを送る方法について教えてください 2 2022/03/29 01:36
- プリンタ・スキャナー プリンター途中までしか印刷しない 8 2022/12/30 17:25
- Visual Basic(VBA) コマンドプロンプトでフォルダ内(デスクトップ)の複数PDFファイルの1ページ目だけを印刷したい 1 2022/09/11 23:33
このQ&Aを見た人はこんなQ&Aも見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
ExcelVBAでPDFを閉じるソース
その他(Microsoft Office)
-
PDFファイルを開き、印刷し、閉じるマクロ
Visual Basic(VBA)
-
PDFファイルを開かずに印刷したい
Visual Basic(VBA)
-
-
4
Adobe Reader を閉じる
その他(Microsoft Office)
-
5
PDFファイルを印刷後、自動でファイルが閉じる方法を教えてください。
その他(ソフトウェア)
-
6
VBA★PDFをPDFアプリで印刷しようと思っていますが上手くゆきません
Visual Basic(VBA)
-
7
VBAでホルダー内のPDFを一括印刷したい
Excel(エクセル)
-
8
EXCEL VBAでPDFファイルを開いて印刷
Visual Basic(VBA)
-
9
vbaでPDFファイルが印刷されない
Visual Basic(VBA)
-
10
vbaから他のアプリを終了
Visual Basic(VBA)
-
11
ExcelVBAにてアプリをタスクマネージャーから強制終了させたいのですが
Visual Basic(VBA)
-
12
【EXCEL-VBA】PDFファイルを開いて印刷したい
Excel(エクセル)
-
13
他のアプリケーションの終了処理
Visual Basic(VBA)
-
14
Excel VBAでPDFファイルをMicrosoft Print to PDFで出力したい
Visual Basic(VBA)
-
15
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
16
vbaでpdfを開いて1ページ目のみ印刷する。
PDF
-
17
ShellExcuteのprint”がExcel2016で実行されない"
Excel(エクセル)
-
18
フォルダ内にあるPDFファイルを一括で印刷する方法※右クリック→印刷はNG
PDF
-
19
エクセルvbaでdocuworksprinterの出力先を設定
Visual Basic(VBA)
-
20
VBscriptでPDFファイルを直接印刷できるようにするためには?
Microsoft ASP
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
macが起動しない!
-
パソコン BIOS画面から進まない
-
画面が真っ黒のままです
-
ウイルスバスター for au を起...
-
PC98で起動ディスクの変更
-
起動不能(NTLDRについて)
-
iMacが起動できなくなりました。
-
起動時にEscを押さないと起動不...
-
USB接続HDDを接続すると...
-
イラストレーターを立ち上げる...
-
GNOMEパネルが表示されず何もで...
-
PCが立ち上がらなくなりました
-
マック上で使用しているワード...
-
システム終了後、しばらくする...
-
PCのメーカーロゴが出るのが遅...
-
dynabook R654 CD-ROMから起動...
-
WindowsNT4.0がプロンプト...
-
HDDを別のノートPCに入れ替えて...
-
PXE-E61: Media test failure, ...
-
PCを起動すると「American Mega...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
画面が真っ黒のままです
-
VBA PDFファイル印刷後のAcroba...
-
dynabook R654 CD-ROMから起動...
-
knoppixを使ったサルベージにつ...
-
PCを起動すると「American Mega...
-
ウイルスバスター for au を起...
-
HDDを別のノートPCに入れ替えて...
-
パソコン BIOS画面から進まない
-
★PCの初期化の方法がわかりま...
-
イラストレーターを立ち上げる...
-
windows xp proが起動しなくな...
-
PCのメーカーロゴが出るのが遅...
-
Bootメニューを消す方法をおし...
-
PC-9821は優先的にフロッピーか...
-
CentOSのテキストベース文字化...
-
起動時にEscを押さないと起動不...
-
どういう意味? PXE-E53って?
-
他人が勝手にログインした形跡...
-
Windows 98 起動ディスク イメ...
-
GNOMEパネルが表示されず何もで...
おすすめ情報