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 :

Copier-Coller par valeur


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut Copier-Coller par valeur
    Bonjour,

    Je souhaiterais copier certaines feuille s (de la numéro 20 jusqu’à la fin)
    Et les coller dans un nouveau classeur. (Copie du format et de la valeur pour éviter les formules)
    Vous trouverez ci-dessous mon code, qui malheureusement ne fonctionne pas.
    Pouvez-vous m’aider s’il vous plait ?


    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
    Function CopieFeuille()
    Dim nbreFeuille As Byte, compteurFeuilleACopier As Byte, compteurFeuilleAColler As Byte
    Dim feuilleACopier, nomFeuille As String, classeurAColler
     
     
    Application.ScreenUpdating = False
    nbreFeuille = ThisWorkbook.Sheets.Count
    compteurFeuilleACopier = 20
     
    Application.Workbooks.Add
     
    classeurAColler = ActiveWorkbook.Name
     
    For compteurFeuilleACopier = 20 To nbreFeuille
    compteurFeuilleAColler = 1
    Workbooks("Base 2016.xlsm").Activate
    Set feuilleACopier = ActiveWorkbook.Sheets(compteurFeuilleACopier)
    nomFeuille = ActiveSheet.Name
     
     
    feuilleACopier.Cells.Copy
     
    With Workbooks(classeurAColler).Sheets(compteurFeuilleAColler).Cells
    .PasteSpecial Paste:=xlPasteAll
    .PasteSpecial Paste:=xlPasteValues
     
    ActiveSheet.Name = nomFeuille
    Application.Worksheets.Add (after)
     
    compteurFeuilleAColler = compteurFeuilleAColler + 1
     
    End With
     
    Next
    Application.CutCopyMode = False
     
    Workbooks(classeurAColler).SaveAs nom & "xlsx"
     
    End Function
    Dernière modification par Invité ; 24/11/2016 à 16h50.

  2. #2
    Membre expérimenté
    Homme Profil pro
    Inscrit en
    Octobre 2012
    Messages
    199
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2012
    Messages : 199
    Par défaut
    Bonjour,

    A tester

    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
     
     
    Function CopieFeuille()
     
    Dim fichierSource As String, fichierCible As String
     
    Dim nbreFeuille As Byte, compteurFeuilleACopier As Byte, compteurFeuilleAColler As Byte
    Dim feuilleACopier, nomFeuille As String, classeurAColler
     
    nom = "TEST"
     
    fichierSource = ActiveWorkbook.Name
    nbreFeuille = ActiveWorkbook.Worksheets.Count
    compteurFeuille = 20
     
    Application.Workbooks.Add
    fichierCible = ActiveWorkbook.Name
     
    compteurFeuilleAColler = 0
     
    For compteurFeuilleACopier = 20 To nbreFeuille
        compteurFeuilleAColler = compteurFeuilleAColler + 1
        feuilleACopier = Workbooks(fichierSource).Sheets(compteurFeuilleACopier).Name
     
     
        Workbooks(fichierSource).Sheets(feuilleACopier).Copy After:=Workbooks(fichierCible).Sheets(compteurFeuilleAColler)
     
    Next compteurFeuilleACopier
     
    Application.CutCopyMode = False
     
    Workbooks(classeurAColler).SaveAs nom & "xlsx"
     
    End Function
    Cordialement,

  3. #3
    Membre Expert
    Homme Profil pro
    PAO
    Inscrit en
    Octobre 2014
    Messages
    2 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : PAO
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2014
    Messages : 2 576
    Par défaut
    bonjour,
    Autre solution, copier le classeur et supprimer les feuilles de 1 à 19
    Cordialement
    Ryu

    La connaissance s’acquiert par l’expérience, tout le reste n’est que de l’information. – Albert Einstein

    Pensez à la Balise [ CODE][/CODE ] - à utiliser via le bouton # => Exemple

    Une fois votre problème solutionné pensez à mettre :resolu: en n'oubliant pas d'indiquer qu'elle est la solution finale choisie ;)

  4. #4
    Invité
    Invité(e)
    Par défaut
    Merci pour vos réponses.

    Mais comment je peux faire pour n'avoir que les valeurs dans les feuilles copiées 20 à 35 (la fin).
    Car il y a des "recherchesV" qui lient ces feuilles avec celles de 1 a 19 inclus.

  5. #5
    Membre Expert
    Homme Profil pro
    PAO
    Inscrit en
    Octobre 2014
    Messages
    2 576
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : PAO
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Octobre 2014
    Messages : 2 576
    Par défaut
    Si tu n'as plus besoin du recherchev mais seulement de la valeur du recherchev
    tu copies les valeurs au même emplacement de ta feuille
    par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets("toto").Range("A1:C25").value = Sheets("toto").Range("A1:C25").value
    la formule du recherchev est supprimée mais on a gardé sa valeur
    C'est comme si tu faisait manuellement un copier / coller spécial => "valeur" sur place
    Cordialement
    Ryu

    La connaissance s’acquiert par l’expérience, tout le reste n’est que de l’information. – Albert Einstein

    Pensez à la Balise [ CODE][/CODE ] - à utiliser via le bouton # => Exemple

    Une fois votre problème solutionné pensez à mettre :resolu: en n'oubliant pas d'indiquer qu'elle est la solution finale choisie ;)

  6. #6
    Invité
    Invité(e)
    Par défaut
    Merci a tous

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

Discussions similaires

  1. [AC-2002] copier coller la valeur du control par double clic
    Par itzik92 dans le forum VBA Access
    Réponses: 2
    Dernier message: 22/01/2011, 22h33
  2. N'autoriser que le copier-coller par valeur sur un onglet
    Par LentilleLocale dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 02/11/2008, 22h46
  3. N'autoriser que le copier-coller par valeur sur un onglet
    Par LentilleLocale dans le forum Excel
    Réponses: 3
    Dernier message: 02/11/2008, 13h31
  4. Copier/coller par automatisation photoshop ?
    Par isa150183 dans le forum Imagerie
    Réponses: 3
    Dernier message: 11/02/2007, 20h55
  5. Comment faire Copier/Coller par code VBA sur INTERNET...
    Par GESCOM2000 dans le forum Access
    Réponses: 5
    Dernier message: 02/01/2006, 13h19

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