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 :

Problème : copie des colonnes d'un onglet vers l'onglet actif


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    345
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2012
    Messages : 345
    Par défaut Problème : copie des colonnes d'un onglet vers l'onglet actif
    Bonjour,

    J'essaye de copier certaines colonnes d'un onglet vers l'onglet actif à l'aide d'un bouton, j'ai un problème avec la fonction que j'ai écrite pour faire cela !


    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
     
     
    Dim ListeTitre()
    Dim WsSources As Worksheet
    Dim WsDonnees As Worksheet
    Dim Nbl As Integer
     
        ListeTitre = Array("Nombre", "Activite", "Date d'arrivée de l'étude", "Date de traitement possible", "Date de réponse demandée", "Date de fin", "mois", "delai")
        Set WsSources = ThisWorkbook.Worksheets("tarifé " & Year(Date))
        Set WsDonnees = ThisWorkbook.ActiveSheet
        Nbl = WsSources.Range("A1").CurrentRegion.Rows.Count
        For i = LBound(ListeTitre) To UBound(ListeTitre)
            Set c = Nothing
            Set c = WsSources.Rows(1).Find(ListeTitre(i), , xlValues, xlWhole)
            If Not c Is Nothing Then
            'WsDonnees.Range(Range("A1"), Range("A1").SpecialCells(xlLastCell)).Clear
     
    'Le problème se trouve sur la ligne de code suivante, je n'arrive pas à trouver la bonne façon de copier :?
     
                WsSources.Range(Cells(1, c.Column), Cells(Nbl, c.Column)).Select
                Selection.Copy
                WsDonnees.Paste
     
            End If
     
        Next i
    Merci d'avance pour votre aide

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WsSources.Range(Cells(1, c.Column), Cells(Nbl, c.Column)).Copy WsDonnees.range("A1")

  3. #3
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    je sais que tu aimes les Resize

    regarde si ça convient à ta problématique

    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
    Sub ioi()
    Dim ListeTitre()
    Dim WsDonnees As Worksheet
        ListeTitre = Array("Nombre", "Activite", "Date d'arrivée de l'étude", "Date de traitement possible", _
                           "Date de réponse demandée", "Date de fin", "mois", "delai")
        With ThisWorkbook
            ' feuille active qui sera la feuille recevant les données (on la nettoie au préalable)
            Set WsDonnees = .ActiveSheet: WsDonnees.UsedRange.Clear
            With .Worksheets("Feuil3")
                ' pour chaque titre
                For i = LBound(ListeTitre) To UBound(ListeTitre)
                    ' recherche en ligne 1
                    Set c = .Rows(1).Find(ListeTitre(i), , xlValues, xlWhole)
                    ' si résultat : écriture de la plage dans la feuille de destination
                    ' on écrit dans la même colonne que celle où on a trouvé le titre
                    If Not c Is Nothing Then .Cells(1, c.Column).Resize(.Range("A1").CurrentRegion.Rows.Count, 1).Copy WsDonnees.Cells(1, c.Column)
                Next i
            End With
        End With
    End Sub

  4. #4
    Membre éclairé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2012
    Messages
    345
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2012
    Messages : 345
    Par défaut
    Citation Envoyé par rdurupt Voir le message
    Bonjour,
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WsSources.Range(Cells(1, c.Column), Cells(Nbl, c.Column)).Copy WsDonnees.range("A1")
    Merci pour votre réponse mais cela ne fonctionne pas ! "La méthode Range de l'objet Worksheet() a échoué" ! Le problème vient de la copie ?

    Je ne sais pas si ça a un rapport avec l'erreur mais je tiens à préciser que toutes les colonnes sont séparées ! C'est à dire que la première est peut être la colonne numéro 10 et la seconde la colonne 3 dans ListeTitre()

    Cordialement

    Citation Envoyé par joe.levrai Voir le message
    Bonjour,

    je sais que tu aimes les Resize
    Wow Joe, ça correspond à 100% à ce que je recherche !

    Merci infiniment

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 09/08/2011, 16h28
  2. [AC-2007] Copie des contacts de ACCESS 2007 vers Contact OUTLOOK 2007
    Par peregna2007 dans le forum Access
    Réponses: 3
    Dernier message: 17/04/2009, 10h09
  3. Réponses: 2
    Dernier message: 19/04/2007, 13h54
  4. copie des données d'un champ vers un autre
    Par cvlpj dans le forum IHM
    Réponses: 10
    Dernier message: 26/12/2006, 22h15
  5. Réponses: 1
    Dernier message: 26/12/2006, 16h23

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