C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

ログ内検索
  • キーワードを複数指定する場合は 半角スペース で区切ってください。
  • 検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
  • [返信]をクリックすると返信ページへ移動します。
キーワード/ 検索条件 /
検索範囲/ 強調表示/ ON (自動リンクOFF)
結果表示件数/ 記事No検索/ ON
大文字と小文字を区別する

No.100895 の関連記事表示

<< 0 >>
■100895  Re[1]: COMオブジェクトで起動したExcelの印刷を行うと例外発生
□投稿者/ KOZ -(2022/11/18(Fri) 13:33:07)
    No100893 (ジェイド さん) に返信
    > 以下のようなコードで、Excelを起動して終了するまで待っている処理を組んでおります。
    
    こんな感じでどうでしょう?
    
    Imports Microsoft.Office.Interop
    Imports System.Runtime.InteropServices
    
    Public Class Form1
    
        <DllImport("user32.dll", SetLastError:=True)> _
        Private Shared Function GetWindowThreadProcessId(ByVal hwnd As IntPtr, _
                            ByRef lpdwProcessId As Integer) As Integer
        End Function
    
    
        Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
            Dim app As New Excel.Application
            Dim books As Excel.Workbooks = app.Workbooks
            Dim book As Excel.Workbook = books.Open("E:\TEST\test.xlsx")
            app.Visible = True
    
            Dim hwnd As IntPtr = New IntPtr(app.Hwnd)
            Dim pid As Integer
            Dim threadId As Integer = GetWindowThreadProcessId(hwnd, pid)
            Marshal.ReleaseComObject(book)
            Marshal.ReleaseComObject(books)
            Marshal.ReleaseComObject(app)
    
            Using p = Process.GetProcessById(pid)
                p.WaitForExit()
            End Using
            MessageBox.Show("EXCEL 終了!")
        End Sub
    
    End Class
    
    
記事No.100893 のレス /過去ログ176より / 関連記事表示
削除チェック/



<< 0 >>

パスワード/

- Child Tree -