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

Excel Discussion :

Contrainte liste déroulante à 255 caractères [XL-2013]


Sujet :

Excel

  1. #1
    Membre régulier Avatar de lerico
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    115
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 115
    Points : 90
    Points
    90
    Par défaut Contrainte liste déroulante à 255 caractères
    Bonjour,

    J'utilise un programme qui me permet de créer des listes déroulantes en fonction d'un filtre, à partir d'un tableau contenu dans une feuille.
    Cela marche parfaitement.

    Ci-dessous le programme :
    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
    Sub CreerListe(NMAG As String)
     
    LigneCourante2 = 2
    TaillePark = Sheets("Feuil2").Cells(1, 1).CurrentRegion.Rows.Count + 1
    i = 1
    Txt = ""
    While LigneCourante2 <> TaillePark
        If Sheets("Feuil2").Cells(LigneCourante2, 3) = NMAG Then
            Txt = Txt & "," & Sheets("Feuil2").Cells(LigneCourante2, 1).Value
            LigneCourante2 = LigneCourante2 + 1
            i = i + 1
        Else
            LigneCourante2 = LigneCourante2 + 1
        End If
    Wend
     If Txt <> "" Then Txt = Right(Txt, Len(Txt) - 1)
    End Sub
    Par contre, après enregistrement et fermeture du fichier, lorsque j'ouvre de nouveau, j'ai les messages d'erreur suivant :
    Nom : image1.jpg
Affichages : 844
Taille : 39,2 Ko
    Nom : image2.jpg
Affichages : 830
Taille : 44,3 Ko

    Cette erreur est due au dépassement du nombre de caractère dans la liste déroulante, qui est supérieur à 255 (Variable Txt).

    J'ai besoin de votre aide pour contourner cette limite car de mon côté, je sèche.
    Il y a peut être une autre façon de créer cette liste ?.

    Merci pour vos réponse.

    Eric

  2. #2
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par lerico Voir le message
    Cette erreur est due au dépassement du nombre de caractère dans la liste déroulante, qui est supérieur à 255 (Variable Txt).
    Il y a peut être une autre façon de créer cette liste ?
    Bonjour,

    Une solution possible avec ce code qui utilise une matrice pour charger la liste déroulante :

    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
     
    Option Explicit
     
    Public MatriceNmag() As Variant
    Public NombreDeValeurs As Long
     
     
    Sub CreerListe(ByVal NMAG As Variant)
     
    Dim I As Long
    Dim DerniereLigne As Long
    Dim AireNmag As Range
    Dim CelluleNmag As Range
     
        With Sheets("Feuil2")
             DerniereLigne = .Cells(.Rows.Count, 1).End(xlUp).Row
             Set AireNmag = .Range(.Cells(2, 1), .Cells(DerniereLigne, 1))
             NombreDeValeurs = WorksheetFunction.CountIf(AireNmag.Offset(0, 2), NMAG)
             If NombreDeValeurs > 0 Then
                ReDim MatriceNmag(NombreDeValeurs - 1)
                I = 0
                For Each CelluleNmag In AireNmag
                    If CelluleNmag.Offset(0, 2) = NMAG Then
                       MatriceNmag(I) = CelluleNmag
                       I = I + 1
                    End If
                Next CelluleNmag
             End If
             Set AireNmag = Nothing
        End With
     
    End Sub
    Et pour charger la combobox de votre userform :

    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
     
    Sub EssaiCreerListe()
     
    Dim ValeurATrouver As Variant
     
        ValeurATrouver = 1
        CreerListe ValeurATrouver
     
        With UserForm1
             If NombreDeValeurs > 0 Then
                .ComboBox1.List = MatriceNmag
                .Show
             Else
                MsgBox "Aucune valeur trouvée pour " & ValeurATrouver & " !", vbCritical
             End If
        End With
     
    End Sub
    Cordialement.

  3. #3
    Membre régulier Avatar de lerico
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    115
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 115
    Points : 90
    Points
    90
    Par défaut
    Bonjour,

    Je te remercie pour ta réponse.

    J'ai effectué plusieurs tests à partir de ta solution mais cela ne correspond pas exactement à mon besoin.
    Après réflexion, j'ai modifié ma méthode en ajoutant sur une feuille à part, les données de la liste de validation, pour ensuite créé un nom que j'associe à la liste.
    Avec ce nouveau procédé, je n'ai plus de problème de contrainte de 255 caractères.

    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
    Sub CreerListe(NMAG As String)
    'Suppresion de la liste
    With Sheets("LISTE").Columns("A:A")
        .ClearContents
    End With
    'Création de la nouvelle liste
    LigneCourante2 = 2
    TaillePark = Sheets("Feuil").Cells(1, 1).CurrentRegion.Rows.Count + 1
    i = 1
    Txt = ""
    While LigneCourante2 <> TaillePark
        If Sheets("Feuil").Cells(LigneCourante2, 3) = NMAG Then
            Sheets("LISTE").Cells(i, 1) = Sheets("Feuil").Cells(LigneCourante2, 1).Value
            LigneCourante2 = LigneCourante2 + 1
            i = i + 1
        Else
            LigneCourante2 = LigneCourante2 + 1
        End If
    Wend
    j = i - 1
    ActiveWorkbook.Names.Add Name:="LISTE", RefersToR1C1:="=LISTE!R1C1:R" & j & "C1"
    End Sub
    Cordialement,

    Eric

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

Discussions similaires

  1. PopUp liste déroulant limité à 255 entrées?
    Par stephane46 dans le forum 4D
    Réponses: 3
    Dernier message: 09/03/2009, 17h22
  2. Couleur de caractère dans liste déroulante
    Par polynesian turtle dans le forum Excel
    Réponses: 2
    Dernier message: 04/01/2009, 20h57
  3. Police de caractères dans liste déroulante
    Par brazilia28 dans le forum 4D
    Réponses: 2
    Dernier message: 27/04/2007, 09h17
  4. Réponses: 4
    Dernier message: 22/05/2006, 11h53
  5. Saisie de plusieurs caractère dans une liste déroulante
    Par Oluha dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 07/03/2005, 14h32

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