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

OpenOffice & LibreOffice Discussion :

[Basic] Liste de Validité [LibreOffice][Tableur]


Sujet :

OpenOffice & LibreOffice

  1. #1
    Membre habitué Avatar de ancel17
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Mars 2007
    Messages
    312
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Bidouilleur

    Informations forums :
    Inscription : Mars 2007
    Messages : 312
    Points : 178
    Points
    178
    Par défaut [Basic] Liste de Validité
    Bonjour,

    Après de nombreuses recherches j'ai adopté ce code pour me faire une liste déroulante dans la cellule C1 avec pour élément de liste les valeurs des cellules "C" & 44 * (i + 1) – 43 :
    Code vb : 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
    Dim Annee As String, strVal As String
    Dim Fl As Object, ShCl As Object, cVal As Object
     
    Set Fl = ShCl.getByName("Rapport")
    strVal = Left(Annee, Len(Annee)3)
    For i = 0 To maxMois - minMois +1 'De 0 à 3 dans l'exemple
        If i > 0 Then
            strVal = strVal & ";" & Fl.getCellRangeByName("C" & 44 * (i + 1)43).String
        End If
    Next i
    MsgBox(strVal) 'Renvoi 2014;2014 - Mars;2014 - Février;2014 - Janvier
    cVal = Fl.getCellRangeByName("C1").getPropertyValue("Validation")
    With cVal
        .IgnoreBlankCells = False
        .setPropertyValue("ErrorAlertStyle" , com.sun.star.sheet.ValidationAlertStyle.STOP)
        .setPropertyValue("Type", com.sun.star.sheet.ValidationType.LIST)
        .setPropertyValue("Operator", com.sun.star.sheet.ConditionOperator.EQUAL)
        .setPropertyValue("ShowErrorMessage", true)
        .setPropertyValue("ErrorTitle", "Erreur de saisie")
        .setPropertyValue("ErrorMessage", "Saisir uniquement une valeur de la liste")
        .setPropertyValue("ShowList", com.sun.star.sheet.TableValidationVisibility.SORTEDASCENDING)
        .setFormula1(strVal) 'Testé avec "" & strVal & "" sans plus de résultat
        .setPropertyValue("formula2","0")
    End With
    Fl.getCellRangeByName("C1").setPropertyValue("Validation",cVal)
    Problème : la liste déroulante est créée avec pour seule valeur : Err 509...

    Quelqu'un voit-il l'erreur ?

    Merci !
    Sigue soñando

  2. #2
    Rédacteur

    Avatar de zoom61
    Homme Profil pro
    ...
    Inscrit en
    Janvier 2005
    Messages
    9 429
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Vienne (Limousin)

    Informations professionnelles :
    Activité : ...
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2005
    Messages : 9 429
    Points : 58 612
    Points
    58 612
    Billets dans le blog
    11
    Par défaut
    Salut,


    • Première erreur avec oBasic, il ne faut pas faire de calcul dans une commande :

    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    strVal = strVal & ";" & Fl.getCellRangeByName("C" & 44 * (i + 1) – 43).String
    devra plutôt s'écrire :
    Code vb : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    nb = 44 * (i + 1) – 43
    strVal = strVal & ";" & Fl.getCellRangeByName("C" & nb).String


    • Seconde erreur, pour une liste, il faut pas mettre ";" mais un saut de ligne chr(10).


    @+.
    N'oubliez pas le Tag afin de faciliter la recherche, et en votant cela permet de mieux la cibler.

    Je ne réponds pas aux messages privés s'ils sont liés à une question technique

  3. #3
    Membre habitué Avatar de ancel17
    Homme Profil pro
    Bidouilleur
    Inscrit en
    Mars 2007
    Messages
    312
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : Bidouilleur

    Informations forums :
    Inscription : Mars 2007
    Messages : 312
    Points : 178
    Points
    178
    Par défaut
    Bonsoir zoom61,

    J'avais testé avec Chr(13) à la place de ";" mais je n'obtenais que la première valeur, soit "2014"…
    Il en est de même avec Chr(10) et les modifications suggérées.

    Je joins un fichier fort simplifié (confidentialité oblige) : le clic sur le bouton de l'onglet "Tableau" lance la macro "liste" sensée créer ma liste de validité dans l'onglet "Rapport".
    Dans la réalité, j'ai un fichier qui me sert d'interface et créé un nouveau fichier et y importe toutes les données, y fait tous les calculs et mises en forme...

    Merci de ton aide !

    Sans nom 1.ods
    -----------------------------------------------------------------------------------------
    Problème résolu !
    Code vb : 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
    Sub liste
    dim cl as object, shcl as object, fl as object, cVal as object
    dim nb as integer
    dim i as byte
    dim strVal As String
     
    cl = thiscomponent
    shcl = cl.sheets 
    Fl = ShCl.getByName("Rapport")
    strVal = """2014""" '"""" & Left(Annee, Len(Annee) – 3) & """" si première valeur variable
    For i = 0 To 3 'De 0 à maxMois - minMois +1 en réalité
        If i > 0 Then
           nb = 44*(i+1)-43
           ' strVal = strVal & Chr(10) & Fl.getCellRangeByName("C" & nb).String
           strVal = strVal & "";"" & """" & Fl.getCellRangeByName("C" & nb).String & """"
        End If
    Next i
     
    cVal = Fl.getCellRangeByName("C1").getPropertyValue("Validation")
    With cVal
        .IgnoreBlankCells = False
        .setPropertyValue("ErrorAlertStyle" , com.sun.star.sheet.ValidationAlertStyle.STOP)
        .setPropertyValue("Type", com.sun.star.sheet.ValidationType.LIST)
        .setPropertyValue("Operator", com.sun.star.sheet.ConditionOperator.EQUAL)
        .setPropertyValue("ShowErrorMessage", true)
        .setPropertyValue("ErrorTitle", "Erreur de saisie")
        .setPropertyValue("ErrorMessage", "Saisir uniquement une valeur de la liste")
        'Ligne suivante désactivée pour ne pas me retrouver dans mon cas avec une liste ou février est avant janvier et mars...
        '.setPropertyValue("ShowList", com.sun.star.sheet.TableValidationVisibility.SORTEDASCENDING)
        .setFormula1(strVal)
        .setPropertyValue("formula2","0")
    End With
    Fl.getCellRangeByName("C1").setPropertyValue("Validation",cVal)
     
    End Sub
    Sigue soñando

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

Discussions similaires

  1. [LibreOffice][Tableur] Ajout de valeur à une liste de validité
    Par ancel17 dans le forum OpenOffice & LibreOffice
    Réponses: 2
    Dernier message: 08/04/2014, 15h31
  2. [AC-2007] Zone de liste avec visual basic access
    Par billiejoe dans le forum IHM
    Réponses: 3
    Dernier message: 14/12/2010, 17h08
  3. Liste des instructions , de controles Visual Basic
    Par Jerem42 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 01/04/2010, 21h40
  4. Controle de validité sur une liste déroulante
    Par francois134 dans le forum IHM
    Réponses: 3
    Dernier message: 04/02/2008, 06h12
  5. Liste Modifiable (Access / Visual Basic)
    Par Berny03 dans le forum VBA Access
    Réponses: 4
    Dernier message: 22/11/2005, 13h30

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