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

Macros et VBA Excel Discussion :

Pb de processus Excel persistents après éxécution d'une requète UPDATE


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Pb de processus Excel persistents après éxécution d'une requète UPDATE
    Bonjour

    En VBA word, je n'arrive pas à fermer tous les processus Excel suite à l'exécution d'une requète UPDATE entre deux feuilles Excel.
    Pour info, hormis ce problème de processus, la requête s'exécute parfaitement.
    Je ne veux pas tuer les processus Excel persistents, car je ne trouve pas ça très propre.
    J'arrive bien à fermer tous les processus avant le refresh de ma requète, mais pas juste après.
    Aussi, je soupçonne que c'est le fait d'avoir deux fichiers Excel qui perturbent l'ensemble.
    Voyez vous d'où vient le problème ?

    Merci d'avance pour votre aide

    Code : 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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    Sub MiseAJour ()
        Dim Liaison, SQL, TabSQL As String
        Dim oRequete As Object
        Dim oSheet1 As Object
        Dim oSheet2 As Object
        Const xlOverwriteCells = 0
        Dim i, j As Integer
     
        'Exemple de données
        Tableau1(1, 1) = "Index WBS"
        Tableau1(1, 2) = "Nom"
        Tableau1(1, 3) = "Durée"
        Tableau1(1, 4) = "Pourcentage_achevé"
        Tableau1(1, 5) = "Début"
        Tableau1(1, 6) = "Fin"
        Tableau1(2, 1) = "Projet_X"
        Tableau1(2, 2) = "Réalisation de la maquette"
        Tableau1(2, 3) = "70 jours"
        Tableau1(2, 4) = "50"
        Tableau1(2, 5) = "01/11/2008"
        Tableau1(2, 6) = "06/02/2009"
        NEnregistrement = 2
     
        Set xls = CreateObject("Excel.Application") 'Ouvre Excel
        'Ligne suivante permet de gèrer les accès simultanés (pas d'accès simultané en fait)
        xls.workbooks.Open filename:=CheminFichiers & NomFichierConfig & ".xls", ReadOnly:=False
     
        'Ouvre une feuille de résultat intermédiaire
        xls.workbooks.Add
        Set oSheet1 = xls.activeworkbook.Worksheets("feuil1")
     
        'Ecrit les données dans la feuille Excel temporaire SaisieTemp
        For j = 1 To 6
            For i = 1 To 2
                oSheet1.Cells(i, j).Value = Tableau1(i, j)
            Next
        Next
        xls.activeworkbook.SaveAs filename:="c:\SaisieTemp.xls"
     
        Set oSheet1 = Nothing
        Set oSheet2 = xls.workbooks("SaisieTemp.xls").Worksheets("Feuil2")
     
     
        'Traitement SQL - requète de mise à jour
        'Liaison ODBC plus permormante pour l'écriture (bug avec OLEDB)
        Liaison = "ODBC;Dsn=Excel Files;Dbq=" & CheminFichiers & NomFichierImport & ".xls" & ";DefaultDir=" & Left(CheminFichiers, Len(CheminFichiers) - 1) & ";driverid=790;maxbuffersize=2048;pagetimeout=5;"
     
        SQL = ""
        Set oRequete = oSheet2.QueryTables.Add(Liaison, oSheet2.Range("A1"), SQL)
        'Ma requête fait appel à deux tables Excel l une ouverte ci-dessus, l autre fermé
        TabSQL = "UPDATE `c:\SaisieTemp`.`Feuil1$` `Feuil1$` INNER JOIN `" & CheminFichiers & NomFichierImport & "`.`Service$` `Service$` ON `Feuil1$`.[Index WBS] = `Service$`.[Index WBS] SET `Service`.[Pourcentage_achevé] = `Feuil1$`.[Pourcentage_achevé], `Service`.[Début] = `Feuil1$`.[Début], `Service$`.Fin = `Feuil1$`.Fin"
        oRequete.CommandText = TabSQL
        oRequete.FieldNames = True
        oRequete.RefreshStyle = xlOverwriteCells
        oRequete.Refresh 'Exécution de la requête j'arrive à fermer tous les processus Excel avant, mais pas après
        oRequete.ResultRange.ClearContents
     
        oRequete.Delete
     
        'Libération des fichiers Excel et normalement fermeture des derniers processus en cours
        Set oRequete = Nothing
        Set oSheet2 = Nothing
        xls.workbooks("SaisieTemp.xls").Close SaveChanges:=False
        xls.workbooks(NomFichierConfig & ".xls").Close SaveChanges:=False
        xls.Quit
        Set xls = Nothing
    End Sub

  2. #2
    Membre confirmé

    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    453
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 453
    Points : 520
    Points
    520
    Par défaut
    C'est probablement que tu ouvres un nouveau classeur, ensuite tu le sauvegardes avec le nom "c:\SaisieTemp.xls" mais tu ne le fermes pas et tu met ta variable à Nothing (le fichier reste en mémoire).

    Ensuite, tu assignes le fichier "SaisieTemp.xls" à une variable (dans le répertoire courrant et non "c:\") et tu le fermes plus tard. Mais tu n'as toujours pas fermé le premier fichier.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Ouiiiiiiiiiiiiiiiii

    C'est bien cela.
    Je ferme une première fois mon fichier "SaisieTemp.xls" avant de mettre ma variable oSheet1 = nothing
    Puis je rouvre mon fichier en utilisant ma deuxième variable oSheet2
    puis je ferme le tout à la fin.
    Et ça marche.

    Merci beaucoup Singular pour cette aide aussi rapide.

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

Discussions similaires

  1. [XL-2007] Processus Excel persistant
    Par Beren69 dans le forum Excel
    Réponses: 1
    Dernier message: 10/03/2014, 17h02
  2. Processus Excel actif apres procedure Access
    Par Cirrus dans le forum VBA Access
    Réponses: 2
    Dernier message: 04/05/2011, 22h22
  3. [VB.NET]Processus Excel persistant
    Par Yolak dans le forum Windows Forms
    Réponses: 8
    Dernier message: 16/10/2010, 13h00
  4. VBSCRIPT : Processus EXCEL persistant
    Par datastep dans le forum VBScript
    Réponses: 6
    Dernier message: 27/08/2010, 13h39
  5. Processus Excel persistant
    Par Mike619 dans le forum VBA Access
    Réponses: 8
    Dernier message: 12/03/2008, 09h15

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