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 :

Erreur : Fichier source introuvable : peut-être l'avez vous déplacé renommé supprimé


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Femme Profil pro
    contrôle de gestion
    Inscrit en
    Novembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : contrôle de gestion

    Informations forums :
    Inscription : Novembre 2015
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Erreur : Fichier source introuvable : peut-être l'avez vous déplacé renommé supprimé
    Bonjour,
    Je suis novice sur vba, et ai écrit une macro qui copie les données issues de tous les fichiers d'un répertoire cible. Et qui les colle dans un fichier de synthèse (une ligne par fichier du répertoire).
    Elle fonctionnait bien jusqu'au moment où j'ai retravaillé sur les fichiers source et le répertoire cible (renommé, déplacé). Voici le message d'erreur : "erreur d'exécution 1004. Désolé nous ne trouvons pas [le nom du 1er fichier de mon répertoire!]. Peut être l'avez vous déplacé renommé ou supprimé?"

    Le problème apparaît sur la ligne Set wb = Workbooks.Open(Fichier_source)
    , où ma souris m'indique wb = nothing tandis que vba parvient bien à identifier le Fichier_source (il m'indique le titre du 1er fichier du répertoire)


    Voici mon code complet :
    merci de vos idées et du temps pris

    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
    Sub Ouverture_plusieurs_Fichiers()
    ' Permet d'ouvrir plusieurs fichiers dans un répertoire
     
    Dim Chemin As String
    Dim Fichier_source As String
    Dim wbRecap As Workbook         'fichier récap
    Dim wsRecap As Worksheet        'feuille où on synthétise les données : "récap evp"
    Dim wb As Workbook              'fichier source
    Dim ws As Worksheet             'feuille où on cherche les données : "suivi temps"
    Dim DernLign As Range           'ligne où l'on écrit les données dans fichier récap
    Dim vFichiers As Variant        'noms des fichiers - pas utile
    Dim rgRecap As Range            'plage où l'on copie les données - doublon avec DernLign ?
     
    ' Neutraliser le rafraîchissement de l'écran
    Application.ScreenUpdating = False
     
    Chemin = "C:\Users\Julie\Documents\macro ouvrir répertoire\"      'Répertoire cible
    Fichier_source = dir(Chemin & "*.xls")                           'Ouvre tous les fichiers .xls* (et xlsx du coup ?)
     
    Do While Len(Fichier_source) > 0
     
    Set wb = Workbooks.Open(Fichier_source)                        
    Set ws = wb.Worksheets("récap")
     
    'ici workbooks (1) = ce fichier de synthèse evp :
    If Workbooks(1).Sheets("récap tous").Range("b1").Value = "JANVIER" Then
    ws.Range("B7:u7").Copy
    Workbooks(1).Sheets("récap tous").Range("A" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial xlPasteValues
    End If
     
    If Workbooks(1).Sheets("récap tous").Range("b1").Value = "FEVRIER" Then
    ws.Range("B8:u8").Copy
    Workbooks(1).Sheets("récap tous").Range("A" & Rows.Count).End(xlUp).Offset(1, 0).PasteSpecial xlPasteValues
    End If
     
    'ici fermer le classeur B sans enregistrer
    wb.Close
     
    ' Libérer la ressource
    Set wb = Nothing
     
    Fichier_source = dir()
     
    Loop
     
    ' Réactiver le rafraîchissement de l'écran
    Application.ScreenUpdating = True
     
    End Sub

  2. #2
    Membre éprouvé
    Avatar de eric4459
    Homme Profil pro
    Ingénieur Gestion de Projets
    Inscrit en
    Avril 2014
    Messages
    605
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes de Haute Provence (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur Gestion de Projets
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2014
    Messages : 605
    Points : 1 124
    Points
    1 124
    Par défaut
    Bonjour Julie,
    Tout d'abord une petite remarque:
    quand tu postes du code utilises les balises (Cliques sur le bouton Diese # et colle ton code au milieu)
    Sinon je crois que tu as la solution a ton problème dans ta question
    jusqu'au moment où j'ai retravaillé sur les fichiers source et le répertoire cible
    Assures toi que tes fichiers sont bien a cet endroit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    C:\Users\Julie\Documents\macro ouvrir répertoire
    sinon modifies le chemin.
    Eric

  3. #3
    Membre émérite
    Inscrit en
    Octobre 2010
    Messages
    1 401
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 1 401
    Points : 2 684
    Points
    2 684
    Par défaut
    Bonsoir

    Essaie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set wb = Workbooks.Open(chemin & Fichier_source)

  4. #4
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonjour,

    Et oui, ça devient récurent. Dir() ne retourne que le nom du fichier et non le chemin complet avec le nom !

  5. #5
    Candidat au Club
    Femme Profil pro
    contrôle de gestion
    Inscrit en
    Novembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : contrôle de gestion

    Informations forums :
    Inscription : Novembre 2015
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Bonjour
    Merci des réponses, ça fonctionne de nouveau même si ça me paraît capricieux (des fois, même message d'erreur qui disparaît au bout de plusieurs tentatives).
    J'en reste là pour le moment
    Merci !

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

Discussions similaires

  1. Erreur fichier multilangue introuvable
    Par sliderman dans le forum Langage
    Réponses: 6
    Dernier message: 02/09/2008, 17h20
  2. Erreur "Fichier source n'a pas pu etre compilé"
    Par gre1307 dans le forum Dev-C++
    Réponses: 1
    Dernier message: 31/01/2008, 20h22
  3. Erreur accès fichier, connexion réseau peut être perdue!
    Par CAPRI_456 dans le forum VBA Access
    Réponses: 4
    Dernier message: 18/12/2007, 21h13
  4. [phpMyAdmin] Le fichier SQL ne peut être lu
    Par venomelektro dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 10
    Dernier message: 10/10/2007, 20h49
  5. Fichier source introuvé par Eclispe.
    Par Phoxtrot dans le forum Eclipse Java
    Réponses: 2
    Dernier message: 10/01/2007, 14h27

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