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 :

ConcatVlookUP sans afficher le premier résultat


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 2
    Par défaut ConcatVlookUP sans afficher le premier résultat
    Bonjour à tous,

    Voilà j'ai trouvé il y a quelques jours de cela un code pour la fonction contactvlookup (auteur Cafeine, merci à lui) et j'aurai aimé apporter une modification. Ci-dessous je vous mets le code de la fonction.

    • J'aimerai ne pas afficher le premier résultat retourné par cette fonction. Cela est-il possible ou pas ?!


    • Si cela n'est pas possible, comment puis-je m'arranger pour que les résultats de cette fonction ne soient pas concaténés et apparaissent dans plusieurs cellules les unes en dessous des autres ?


    En vous remerciant pour votre aide,

    Bonne journée à tous

    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
    Function ConcatVLookUp(ByVal ValRecherche, _
                           ByVal TabMatrice As Range, _
                           ByVal IndexCol, _
                  Optional ByVal blnConcat As Boolean = False, _
                  Optional ByVal Separateur = ";") As Variant
     
    ' Permet une recherchev sur des caractères génériques
    '
    Dim c As Range
     
    application.Volatile
     
    For Each c In TabMatrice.Cells
        If c.Value Like ValRecherche Then
            ConcatVLookUp = ConcatVLookUp & Separateur & c.Offset(0, IndexCol - 1).Value
            If Not blnConcat Then Exit For
        End If
    Next c
    ConcatVLookUp = Mid(ConcatVLookUp, Len(Separateur) + 1)
     
    Set c = Nothing
    End Function

  2. #2
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Citation Envoyé par guilouuu Voir le message
    j'aimerai ne pas afficher le premier résultat retourné par cette fonction.
    Bonjour,

    Il suffit de modifier le traitement de la chaîne de caractères du résultat final
    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
    Function ConcatVLookUp(ByVal ValRecherche, _
                           ByVal TabMatrice As Range, _
                           ByVal IndexCol, _
                  Optional ByVal blnConcat As Boolean = False, _
                  Optional ByVal Separateur = ";") As Variant
     
    ' Permet une recherchev sur des caractères génériques
    '
    Dim c As Range
     
    Application.Volatile
     
    For Each c In TabMatrice.Cells
        If c.Value Like ValRecherche Then
            ConcatVLookUp = ConcatVLookUp & Separateur & c.Offset(0, IndexCol - 1).Value
            If Not blnConcat Then Exit For
        End If
    Next c
    ConcatVLookUp = Mid(ConcatVLookUp, InStr(2, ConcatVLookUp, Separateur) + 1)
     
    Set c = Nothing
    End Function
    Pour plus d'info, voir ce que font les instructions Mid et InStr là --> http://silkyroad.developpez.com/VBA/...nesCaracteres/
    ou dans l'aide VBA en sélectionnant le terme recherché dans le code et en cliquant sur F1

Discussions similaires

  1. [WD15] Afficher le premier résultat d'une table dans une requête
    Par bestmoroco dans le forum WinDev
    Réponses: 3
    Dernier message: 20/01/2015, 00h26
  2. Réponses: 4
    Dernier message: 10/10/2011, 09h08
  3. Afficher le premier résultat d'une requête
    Par ab1609 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 15/03/2011, 13h53
  4. Réponses: 23
    Dernier message: 17/04/2008, 21h36
  5. Exécuter requête sans afficher le résultat
    Par picatchou dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 18/09/2006, 22h32

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