IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VBA Access Discussion :

Ouvrir plusieurs classeurs Excel dans un seul processus


Sujet :

VBA Access

  1. #1
    Membre régulier Avatar de zoopsys
    Homme Profil pro
    Inscrit en
    Août 2008
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 68
    Points : 80
    Points
    80
    Par défaut Ouvrir plusieurs classeurs Excel dans un seul processus
    Bonjour,

    Je souhaiterai ouvrir plusieurs classeurs Excel (à partir d'Access) dans un seul processus Excel.

    le code que j'utilise actuellement est le suivant, mais il m'ouvre plusieurs processus Excel.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim  xxx As String
     
    strExcel = "C:\Program Files\Microsoft Office\OFFICE10\EXCEL.EXE"
    strClasseur = xxx
    Shell Chr(34) & strExcel & Chr(34) & " " & Chr(34) & strClasseur & Chr(34),   vbMaximizedFocus

    j'ai aussi essayé çà mais çà donne bien évidemment le même résultat que précédemment :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Dim  xxx As String
    Dim appExcel As Excel.Application 'Application Excel
    Dim wbExcel As Excel.Workbook 'Classeur Excel
     
    'Ouverture de l'application
    Set appExcel = CreateObject("Excel.Application")
    appExcel.Visible = True
    'Ouverture d'un fichier Excel
    Set wbExcel = Workbooks.Open(xxx)
    Merci.

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonjour,

    Il faut d'abord essayer d'utiliser GetObject, puis ci cela échoue, CreateObject.

    Exemple:
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub OuvrirDesClasseurs()
     
    'Ouverture d'un fichier Excel
    OuvrirClasseurExcel "C:\Mes Documents\Excel\fichier1.xls"
     
    'Ouverture d'un fichier Excel
    OuvrirClasseurExcel "C:\Mes Documents\Excel\fichier2.xls"
     
    'Ouverture d'un fichier Excel
    OuvrirClasseurExcel "C:\Mes Documents\Excel\fichier3.xls"
     
    End Sub
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    Sub OuvrirClasseurExcel(strClasseur As String)
    Dim appExcel As Excel.Application 'Application Excel
    Dim wbExcel As Excel.Workbook 'Classeur Excel
    Dim blnExcelRunning As Boolean
     
    'Ouverture de l'application
    On Error Resume Next
    Set appExcel = GetObject(, "Excel.Application")
    On Error GoTo 0
    If appExcel Is Nothing Then
       ' Excel n'est pas ouvert (aucune instance)
       Set appExcel = CreateObject("Excel.Application")
    Else
       blnExcelRunning = True
    End If
    appExcel.Visible = True
     
    If blnExcelRunning Then
       Debug.Print "Une instance d'Excel existe déjà"
    Else
       Debug.Print "Aucune instance d'Excel -> Ouverture d'Excel"
    End If
     
    'Ouverture du fichier Excel
    appExcel.Workbooks.Open strClasseur
    End Sub
    La sub OuvrirClasseurExcel tente dans un premier temps de récupérer une instance d'Excel avec GetObject.
    Si GetObject échoue, l'objet appExcel vaut Nothing.
    On utilise alors CreateObject pour ouvrir Excel.

    Cette partie du code
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    If blnExcelRunning Then
       Debug.Print "Une instance d'Excel existe déjà"
    Else
       Debug.Print "Aucune instance d'Excel -> Ouverture d'Excel"
    End If
    sert juste à tracer le fonctionnement du code.

    A+

  3. #3
    Membre régulier Avatar de zoopsys
    Homme Profil pro
    Inscrit en
    Août 2008
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 68
    Points : 80
    Points
    80
    Par défaut
    Merci LedZeppII

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [PPT-2003] Copier le contenus de plusieurs cellules Excel dans une seule liste-texte ppt
    Par mimilll dans le forum VBA PowerPoint
    Réponses: 8
    Dernier message: 02/06/2009, 19h45
  2. [Excel] Afficher plusieurs fichiers excel dans un seul fichier
    Par naru40001 dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 07/01/2009, 14h50
  3. Concaténer plusieurs feuilles excel Dans 1 seule
    Par joshua12 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/11/2008, 17h09
  4. ouvrir plusieurs fichier texte dans une seule feuille
    Par popoye dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 21/04/2008, 15h28
  5. Réponses: 28
    Dernier message: 22/05/2006, 16h25

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo