只今、VB6のDataReportを使用して500ページほど
印刷したいのですが100ページほどしか印刷されません。
原因は印刷が完了する前にDataReportの解放を行っているためです。
DataReportの解放前に数秒プログラムを停止させる方法があるのですが
できればPrintreportメソッドで出力が完了したかの判断を行いたいです。
それに近い質問があり以下のように実行したのですがうまくいきませんでした。
具体的な解決方法があればとてもありがたいです。
【プログラムロジック.vbs】
'起動プロセスのオープン(状態の取得準備)
Public Declare Function OpenProcess Lib "KERNEL32" _
(ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, _
ByVal dwProcessId As Long) As Long
'起動プロセスとのシンクロ(待機する)
Public Declare Function WaitForSingleObject Lib "KERNEL32" _
(ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
'起動プロセスのクローズ(終了)
Public Declare Function CloseHandle Lib "KERNEL32" _
(ByVal hObject As Long) As Long
'起動プロセスが実行中か調べる(状態の取得)
Public Declare Function GetExitCodeProcess Lib "KERNEL32" _
(ByVal hProcess As Long, lpExitCode As Long) As Long
Public Const SYNCHRONIZE = &H100000
Public Const INFINITE = &HFFFF
【プログラムロジック.frm】
Dim IDProcess As Long
Dim hProcess As Long
Dim ret As Long
IDProcess = Control.PrintReport
hProcess = OpenProcess(SYNCHRONIZE, 1, IDProcess)
ret = WaitForSingleObject(hProcess, INFINITE)
ret = CloseHandle(hProcess)
上記方法でテストしたのですが
「IDProcess」には「1」が返ります。
「hProcess」には「0」が返ります。
スプールにJOBがたまるまで「WaitForSingleObject」で
WAITされると思ったのですがとくに待ちになりませんでした。
環境はWindowsXP、Windows2003サーバです。
よろしくお願いします。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
解放前に以下の記述をします。
'非同期操作終了待
Do While drt.AsyncCount > 0
DoEvents
Loop
sleep入れたほうがいいかも?
No.1
- 回答日時:
DataReportのPrintReportは クッキーを返すだけでProcesハンドルを返すわけではないと思います
アウトプロセスで起動されてるなら EnumProcessesなどでプロセスIDを取得してEnumProcessModulesでモジュールハンドルを取得
GetModuleFileNameExでファイル名を取得して捜し求めるプロセスハンドルを特定
といった手順が必要でしょう … たぶんインプロセスで動いてると思うけど
それより DataReportのErrorイベントでエラーになっている原因を探ったほうがいいように思います
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) Vba Userformを前面に出すについて 3 2022/04/15 12:29
- Excel(エクセル) 【マクロ】スクショ印刷がうまく動かない件 5 2022/12/06 17:37
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたい 6 2023/01/23 12:00
- Visual Basic(VBA) 数式が消える 1 2023/03/19 16:55
- Visual Basic(VBA) VBA リボンののリカバリーでオーバーフローエラーになります 2 2023/07/04 19:07
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
explorer.exeが異様にメモリを食う
-
他のEXEが起動しているかの確認
-
SendMessageが失敗するときがある
-
ADOでアクセスのレコードに...
-
バックグラウンドのプロセスの...
-
共有メモリを使う場合のCPU負荷...
-
警告『 別のプロセスで使用され...
-
VBでエクセルを起動し、プロ...
-
C#でのbatファイル実行結果取得
-
C++でシェルを起動
-
Linuxのchdir(カレントディレク...
-
パソコンに出てくるじゃまな表...
-
forkについて
-
OSPFでプロセスを分ける意義に...
-
CreateProcessでアプリが終了し...
-
起動中の他のプログラム(orプ...
-
タスクマネージャーのプロセス...
-
シートのコピーでプロセスが残...
-
非表示になったエクセルは?
-
子プロセスのデバッグ方法について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
バックグラウンドのプロセスの...
-
explorer.exeが異様にメモリを食う
-
なぜ女性は男性が忘れたことを...
-
タスクマネージャーのプロセス...
-
プロセスのアタッチ・デタッチ...
-
非表示になったエクセルは?
-
Process.Startの戻り値を後で取得
-
C#でのbatファイル実行結果取得
-
プロセスIDからウィンドウハ...
-
c言語でプロセスIDを調べたい
-
Linuxでのスレッド間メッセージ...
-
プロセスIDの取得方法について
-
ADOでアクセスのレコードに...
-
怪しいプロセス教えてください。
-
vb.netでEXCEL起動がうまくでき...
-
別のプロセスの関数を呼び出す...
-
C++のプログラムをバックグラウ...
-
Visual C++からpingを実行して...
-
VBS(WSH)で開いたIEのウィンド...
-
IISがフリーズ
おすすめ情報