Bonjour,

J'ai un programme vba qui va rechercher des données dans un claseur (en fonction du n°sem choisi) nommé "MC_Shootage" puis, me les colle dans un autre nommé "MC_Commun".

Maintenant, on me demande de faire pareil sauf que au lieu d'aller chercher 1 seul fichier ("MC_Shootage"), il faut que le pgm me cherche 3 autres fichiers ("MC_Plastique", "MC_Finition" et "MC_Expédition")en plus de "MC_Shootage".

Comment gérer l'ouverture de plusieurs fichiers ?
Existe-t-il une fonction multiFichier ou qqch comme ça?

Voici mon pgm:

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
Sub Dechet_Finition_Hebdo()
 
'Identification des chemins et des fichiers
 
    Dim Chemin As String, WbDestination As Workbook, WbSource As Workbook
    Dim Fichier As String
    Dim Semaine As Long, L As Long, x As Long
    Set WbDestination = ThisWorkbook
    L = WbDestination.Worksheets("Donnees").Range("A65536").End(xlUp).Row + 1
    WbDestination.Worksheets("Donnees").Range("A6:N" & L).ClearContents
 
     'Chemin = "X:\30_QUALITE\307_Gestion_de_service\AAAA-Main-Courante-Atelier\Recherches pour MC_commun\MC_commun"
    Chemin = ThisWorkbook.Path    'si les 2 fichiers dans même dossier
 
    'demande à l'utilisateur le numéro de semaine, semaine en cours par défaut
    Semaine = InputBox("N° de la semaine", "SEMAINE", DatePart("ww", Date, vbMonday) - 1)
    If Semaine = 0 Then Exit Sub
    Fichier = "MC_Shootage.xlsm"
    If FichierExiste(Chemin & "\" & Fichier) Then
 
    'ouverture du fichier en lecture seule
        Workbooks.Open Filename:=Chemin & "\" & Fichier, UpdateLinks:=0, ReadOnly:=True
        Set WbSource = ActiveWorkbook
        On Error Resume Next
        x = Application.WorksheetFunction.CountIf(WbSource.Worksheets("Synthese").Range("B5:B1000"), "=" & Semaine)
            If x > 0 Then
        With WbSource.Worksheets("Synthese")
                'Transfert des données
                'exemple pour ajout de ligne(s)
                For Each cel In .Range("B6:B1000")
                    If cel = Semaine Then
                        L = WbDestination.Worksheets("Donnees").Range("A65536").End(xlUp).Row + 1
                         .Range("A" & cel.Row & ":N" & cel.Row).Copy Destination:=WbDestination.Worksheets("Donnees").Range("A" & L)
                    End If
                Next cel
        End With
 
        WbSource.Close SaveChanges:=False
            Else
        WbSource.Close SaveChanges:=False
            End If
      End If
End Sub
 
Function FichierExiste(NomFichier As String) As Boolean
    FichierExiste = Dir(NomFichier) <> "" And NomFichier <> ""
End Function
Merci pour votre aide