Bonjour à tous,
JE suis en train d'écrire une macro qui à partir d'un fichier principal crée un second fichier contenant des onglets du premier fichier.
Pour cela j'ai besoin de copier les onglets d'un fichier à l'autre.
Voici le code que j'utilise:
Le problème est que la copie ne fonctionne pas.
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 Private Sub Extraire_Click() compt = ThisWorkbook.Worksheets.Count Dim xlApp As Excel.Application Dim xlBook As Excel.Workbook Dim xlBook1 As Excel.Workbook Set xlBook1 = ThisWorkbook 'On créer l'objet Excel Set xlApp = CreateObject("Excel.Application") 'On défini le nombre d'onglets (ici 0) xlApp.SheetsInNewWorkbook = 1 'On ajoute un classeur Set xlBook = xlApp.Workbooks.Add 'On donne un nom au classeur xlBook.SaveAs ("Extraction.xls") 'On rend le classeur visible xlApp.Visible = True 'On créer la page de garde xlBook1.Sheets("Page de garde").Copy xlBook.Sheets("Feuil1") ActiveSheet.Name = "Liste de Fiches" For r = 5 To compt n = Feuil2.Cells(r, 1) i = InStr(xlBook1.Sheets(r).Cells(1, 3), Specs.Value) j = InStr(xlBook1.Sheets(r).Cells(1, 4), Projet.Value) k = InStr(xlBook1.Sheets(r).Cells(1, 5), Produit.Value) l = InStr(xlBook1.Sheets(r).Cells(1, 6), Fonction.Value) If i > 0 And j > 0 And k > 0 Then xlBook.Activate xlBook.Sheets().Add After:=xlBook.Worksheets(xlBook.Worksheets.Count) xlBook.Sheets(xlBook.Worksheets.Count).Name = xlBook1.Sheets(r).Cells(1, 1) xlBook1.Sheets(r).Copy after:=xlBook.Sheets(xlBook.Worksheets.Count) End If Next r End Sub
Pouvez vous m'éclairer sur le sujet.
Merci d'avance.
Partager