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 :

Extraire fichiers d'un dossier compressé avec vba


Sujet :

Macros et VBA Excel

  1. #1
    thomahh
    Invité(e)
    Par défaut Extraire fichiers d'un dossier compressé avec vba
    Bonjour à tous,

    je recherche comment extraire des fichiers d'un dossier compressé avec VBA.

    J'utilise 7zip et excel 2010. J'ai un programme, mais quand je le lance, il ne se passe rien.

    Merci 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
    Sub Dezipper()
     
        Dim CheminZip As String
        Dim DossierUnZip As String
        Dim FichierZip As Variant, ShellStr As String
     
        CheminZip = "C:\program files\7-Zip\"
     
        DossierUnZip = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges"
        FichierZip = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges\documents-export-2012-08-01.zip"
        ShellStr = CheminZip & "7z.exe x -aoa -r" _
                 & " " & Chr(34) & FichierZip & Chr(34) _
                 & " -o" & Chr(34) & DossierUnZip & Chr(34) & " " & "*.*"
     
     
     
    End Sub

  2. #2
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Bonjour,

    C'est normal qu'il ne se passe rien parce que dans ton code tu ne fais qu'initialisé des variables, tu ne lances pas le programme via la commande Shell.

    Jette un oeil sur cette discussion --> http://www.developpez.net/forums/d27...r-fichier-vba/

  3. #3
    thomahh
    Invité(e)
    Par défaut
    Ok, j'ai essayé d'adapter le programme sur le lien que tu m'as donné.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Private Sub Commande3_Click()
     
    CheminWinZip = "C:\program files\7-Zip\"
     
    DossDest = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges"
    NomArchive = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges\documents-export-2012-08-01.zip"
     
    Shell (CheminWinZip & "7z.exe x -aoa -r """ & NomArchive & """ """ & DossDest & """")
    End Sub
    Il ne se passe toujours rien...

  4. #4
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    L'utilisation de 7-zip via VBA est un peu plus complexe, je vois que tu as un bout de code réalisé par Ron Debruin mais il faut le code complet...

    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
    Declare Function OpenProcess Lib "kernel32" _
                                 (ByVal dwDesiredAccess As Long, _
                                  ByVal bInheritHandle As Long, _
                                  ByVal dwProcessId As Long) As Long
     
    Declare Function GetExitCodeProcess Lib "kernel32" _
                                        (ByVal hProcess As Long, _
                                         lpExitCode As Long) As Long
     
    Public Const PROCESS_QUERY_INFORMATION = &H400
    Public Const STILL_ACTIVE = &H103
     
    Public Sub ShellAndWait(ByVal PathName As String, Optional WindowState)
        Dim hProg As Long
        Dim hProcess As Long, ExitCode As Long
        If IsMissing(WindowState) Then WindowState = 1
        hProg = Shell(PathName, WindowState)
        hProcess = OpenProcess(PROCESS_QUERY_INFORMATION, False, hProg)
        Do
            GetExitCodeProcess hProcess, ExitCode
            DoEvents
        Loop While ExitCode = STILL_ACTIVE
    End Sub
    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
    Sub Dezipper()
     
    Dim CheminZip As String
    Dim DossierUnZip As String
    Dim FichierZip As Variant, ShellStr As String
     
    CheminZip = "C:\program files\7-Zip\"
     
    DossierUnZip = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges\"
    FichierZip = "C:\Users\tliberti\Desktop\Stage bureau\Travaux\Détopages Litiges\documents-export-2012-08-01.zip"
    ShellStr = CheminZip & "7z.exe x -aoa -r" _
             & " " & Chr(34) & FichierZip & Chr(34) _
             & " -o" & Chr(34) & DossierUnZip & Chr(34) & " " & "*.*"
     
    ShellAndWait ShellStr, vbHide
     
    End Sub

  5. #5
    thomahh
    Invité(e)
    Par défaut
    Merci beaucoup.

Discussions similaires

  1. manipulation des fichiers et dossiers avec VBA excel
    Par GBAGO dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 29/07/2007, 23h30
  2. [VBA-E] parcours de fichiers et de dossiers
    Par trach.sam dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 22/08/2006, 17h34
  3. Lire un fichier XML avec VBA
    Par Mouse dans le forum Général VBA
    Réponses: 1
    Dernier message: 15/06/2006, 19h56
  4. Réponses: 3
    Dernier message: 22/05/2006, 17h00
  5. [VBA-E]Compter nombre de fichier dans un dossier
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 22/05/2006, 14h36

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