Code VBA Copier Collage spéciale en valeur (sans formule)
Fermé
Sphynxitos
-
2 mai 2016 à 15:43
ThauTheme Messages postés 1442 Date d'inscription mardi 21 octobre 2014 Statut Membre Dernière intervention 29 juillet 2022 - 2 mai 2016 à 17:28
ThauTheme Messages postés 1442 Date d'inscription mardi 21 octobre 2014 Statut Membre Dernière intervention 29 juillet 2022 - 2 mai 2016 à 17:28
A voir également:
- Code VBA Copier Collage spéciale en valeur (sans formule)
- Formule si et - Guide
- Excel mise en forme conditionnelle formule - Guide
- Formule excel pour additionner plusieurs cellules - Guide
- Le code ascii en informatique - Guide
- Formule excel moyenne - Guide
1 réponse
ThauTheme
Messages postés
1442
Date d'inscription
mardi 21 octobre 2014
Statut
Membre
Dernière intervention
29 juillet 2022
160
2 mai 2016 à 17:28
2 mai 2016 à 17:28
Bonjour Sphynxitos, bonjour le forum,
Essai comme ça :
Mais avec deux variables de plus c'est tellement plus simple à coder :
Essai comme ça :
.Columns(Col).Copy WbkColle.Sheets("Commande").Cells(1, WbkColle.Sheets("Commande").Cells.Columns.Count).End(xlToLeft).Offset(0, 1).PasteSpecial(xlPasteValues)
Mais avec deux variables de plus c'est tellement plus simple à coder :
Sub ImporterBudget() Dim Fichier Dim CY As Workbook 'déclare la variable CY (Classeur copY) Dim OY As Worksheet 'déclare la variable OY (Onglet copY) Dim CE As Workbook 'déclare la variable CE (Classeur collE) Dim OE As Worksheet 'déclare la variable OE (Onglet collE) Dim Colonnes(), Col As Integer, Resultat As Variant 'On attribue à la variable CE le fichier actuel (celui qui contient la macro) Set CE = ThisWorkbook Set OE = CE.Sheets("Commande") 'Nom des entêtes de colonnes à importer Colonnes = Array("Code nana", "Métier", "Produit", "Client") 'Sélection du fichier Fichier = Application.GetOpenFilename("Fichiers Excels, *.xls*") 'En cas de clic sur "ANNULER" If Fichier <> False Then 'On ouvre le fichier en question Set CY = Workbooks.Open(Fichier) Set OY = CY.Sheets("Import") 'Boucle sur toutes les entêtes des colonnes For Col = 1 To OE.Cells(1, OE.Cells.Columns.Count).End(xlToLeft).Column 'teste si l'entête correspond à un des noms des colonnes à copier Resultat = Application.Match(OE.Cells(1, Col), Colonnes, 0) 'Si l'entête est trouvée (colonne à copier) If Not IsError(Resultat) Then 'Copié - Collé ==> ADAPTER NOM de la feuille ou il faut coller OE.Columns(Col).Copy OY.Cells(1, OY.Cells.Columns.Count).End(xlToLeft).Offset(0, 1).PasteSpecial (xlPasteValues) End If Next Col End With CY.Close End If End Sub