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 :

Recopier les valeurs d'un dictoinnaire en ligne plutôt qu'en colonne


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 177
    Par défaut Recopier les valeurs d'un dictoinnaire en ligne plutôt qu'en colonne
    Bonjour les maîtres du vba

    Ci dessous le code que j'ai élaboré grâce aux tutoriels pour creer une liste de nom;
    Mon probleme, cela donne une liste de nom en colonne à partir de C4 et je voudrais une liste en ligne à partir de C4

    Votre aide serait la bienvenue

    Cordialement
    Lps02


    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
    Private Sub Propriétaire()
    Dim Dico As Object
    Dim j As Range
    Dim d
    Dim b As Long
    Set Dico = CreateObject("Scripting.Dictionary")
    With Worksheets("lotissement")
        For Each j In .Range("N12:N" & .Cells(.Rows.Count, 1).End(xlUp).Row)
            If Not Dico.exists(Trim(j.Value)) Then Dico.Add Trim(j.Value), Trim(j.Value)
        Next j
            b = 4
            For Each d In Dico.items
            .Range("C" & b) = d   'pour recopier la liste des éléments uniques à partir de la cellule B2
            b = b + 1
            Next d
     
     
    End With
     
     
    End Sub

  2. #2
    Expert éminent


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Par défaut
    bonjour,

    modifie la ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    .Range("C" & b) = d   'pour recopier la liste des éléments uniques à partir de la cellule B2
    en utilisant .Cells ( ligne,colonne)...



  3. #3
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonjour,

    perso, je propose cette solution :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ...
        b = 4
        .Range("C" & b, .Cells(4, Dico.Count + b - 1)) = Dico.items
    ...
    Qui évite la boucle

    Bonne journée
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 177
    Par défaut
    Merci à vous deux

    Cela fonctionne

    A+
    Cordialement
    lps02

  5. #5
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Janvier 2012
    Messages
    177
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 177
    Par défaut
    Bonsoir Casefayere

    Un petit soucis avec ta méthode tout de même, il y a une cellule apres les cellules de données où il est marqué (dans la feuille excel) "N/A"

    ton avis??
    Je n'ai pas ce soucis avec la boucle ....
    Cordialement
    lps02

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

Discussions similaires

  1. Copier les valeurs des champs d'une ligne dans la ligne suivante
    Par xoxo72 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 15/09/2014, 10h10
  2. Réponses: 0
    Dernier message: 28/02/2014, 16h17
  3. Réponses: 1
    Dernier message: 19/10/2011, 14h57
  4. recopier les valeur en fonction de combobox en cascade
    Par adriennoob dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 01/04/2010, 19h00
  5. Réponses: 2
    Dernier message: 21/06/2006, 17h57

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