vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
Brandneu! sevEingabe v3.0 - Das Eingabecontrol der Superlative!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2025
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

VB.NET - Fortgeschrittene
Re: Excel schliessen 
Autor: schillerfrau
Datum: 25.02.07 18:41

Hallo zusammen,

ich habe auch ein Problem mit Excel schließen. Daher fand ich auf dieser Seite eure Lösung und probierte es aus. Leider bekam ich bei procs(i).MainModule.BaseAddress.ToInt32 eine Fehlermeldung. Der Trick mit Dim h As Integer = Me._excelAppl.Hinstance hat nicht geholfen. Liegt wohl an meinem Excel dass älter ist. Von daher hab ich im Netz einen Code gefunden, den ich euch nicht vorenthalten möchte:

'Prozessliste, bevor ich einen Excel-Prozess starte
process1 = Process.GetProcesses()
oExcel = CreateObject("Excel.Application")
'Prozessliste, nachdem ich einen Excel-Prozess gestartet hab
process2 = Process.GetProcesses()
process1 & process2 speichere ich in einer globalen Variablen, damit ich von überall darauf Zugriff hab. Zusätzlich definiere/initialisiere ich eine Variable namens procId:

Dim process1() As Process
Dim process2() As Process
Dim procId As Integer = 0
Wenn jetzt in meinem Try..Catch-Block ein Fehler passiert, wird der Catch- bzw. Finally-Teil bei mir mit folgendem Code ausgeführt:

        Try
         ...
        Catch
        Finally
 
            Dim bMonProcessXL As Boolean
 
            For j As Integer = 0 To process2.GetUpperBound(0)
                If process2(j).ProcessName = "EXCEL" Then
                    bMonProcessXL = True
                    For i As Integer = 0 To process1.GetUpperBound(0)
                        If process1(i).ProcessName = "EXCEL" Then
                            If process2(j).Id = process1(i).Id Then
                                bMonProcessXL = False
                                Exit For
                            End If
                        End If
                    Next i
 
                    If bMonProcessXL = True Then
                        'Jetzt, wo ich die genaue ID habe, kann ich sie töten. 
                        ' excellAppl.Hinstance  
                        'funktioniert nicht mit Excel 2000, während diese 
                        ' Methode immer geht!
                        procId = process2(j).Id
                        Process.GetProcessById(procId).Kill()
                        Exit For
                    End If
                End If
            Next j
            End
        End Try
Auch wenn dieser Beitrag älter ist, vielleicht ist es dem einen oder anderen ja zunutze

Habt nen schönen Abend,
lgk
alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
Excel schliessen1.068immerSuchender30.03.06 11:41
Re: Excel schliessen761Maywood30.03.06 11:50
Re: Excel schliessen704immerSuchender31.03.06 08:54
Re: Excel schliessen751Maywood31.03.06 11:30
Re: Excel schliessen692immerSuchender31.03.06 11:37
Re: Excel schliessen777Maywood31.03.06 13:34
Re: Excel schliessen1.244schillerfrau25.02.07 18:41

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2025 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel