bizarre ta question, ou alors je l'ai mal comprise...
C'est plus simple de compter les lignes lorsque tu les saisis que d'analyser le vba par une macro après coup.
Tu peux expliquer le but pour éclaircir ?
Sinon tu comptes quoi pour :
Effectivement, ça peut sembler bizarre.
Dans la fonction il y a un certain nombre de Case, mais il se peut qu'on en rajoute.
Toujours dans la fonction, on dresse un tableau qui recueille la valeur correspondant à chaque Case. Pour ce faire, il faut rédiger une boucle commençant par le 1er case et finissant au dernier. Peut-on, sans avoir à stipuler manuellement le numéro du dernier Case, connaître automatiquement celui-ci ?
C'est essentiellement par curiositçe que je pose la question.
On ne sait pas ce qui est fait dans chaque Case.
Si c'est la même opération, je ferais plutôt l'inverse. Un array avec les données (dans le code ou récupéré d'un tableau sur feuille facile à compléter) et une boucle dessus.
C'est le choix que j'aurais fait aussi, autant aller au plus simple.
Si je peux me permettre :
- je n'aime pas le On Error Resume Next ;-)
- tu n'as pas mis de valeur par défaut à Optional ChxLangue As Byte et tu ne traites pas le cas où il est omis.
Et ça tu ne peux pas vu que tu l'as typé.
A mon sens, tu as 2 choix 'raisonnables' pour les paramètres optionnels :
- Variant : tu peux utiliser IsMissing()
- typé autre que Variant : lui mettre une valeur par défaut pour ne pas avoir d'erreur en cas d'omission
Si non typé, tu peux autoriser de passer aussi bien le n° que la langue :
VB:
Case 1, "Afrikaans": langue = Array(..)
Et tu utilises IsMissing() soit pour retourner une valeur d'erreur, soit pour lui fixer une valeur par défaut. A ton choix.
Je pense que tu le sais mais au cas où...
Si ta fonction peut retourner plusieurs paramètres différents, plutôt que de multiplier les booléens tu peux lui passer une chaine avec le nom du paramètre voulu (variant).
Si IsMissing() => jour (par défaut donc)
Si "langue" ou "items" ou ... => le paramètre demandé
Là tu n'en as que 2, si plus ça devient de plus en plus scabreux.
Avec pour moi l'avantage d'auto-documenter l'appel.
(sauf si elle est destinée à être appelée des milliers de fois et où la vitesse prime)
eric
Tu as tout à fait raison pour le « On Error Resume Next ». J’en avais eu besoin à un moment donné, et j’ai oublié de le lourder (ce que je viens de faire).
À quoi peut donc bien servir cette fonction ? Ou, mieux, comment l’utiliser ? Elle est destinée à être utilisée avec un ComboBox et un SpinButton.
Le ComboBox emmagasine les noms de langues (d’où la nécessité de créer une liste des langues présentes dans la fonction). À partir de celui-ci, on choisit une langue : dans une cellule, le jour de la semaine prend le nom de celui de la langue choisie.
Le SpinButton, lui, permet, lors de ses incréments et décréments, de modifier la date et, par voie de conséquence, les noms des jours de la semaine (qui défilent) dans la langue auparavant choisie.
On pourrait, peut-être, rendre la fonction plus versatile avec des « IsMissing() », mais franchement, je ne vois pas réellement dans quel but. Normalement, il ne devrait y avoir aucune plantade, vu qu’en permanence la fonction est gérée, sans aucune fantaisie, par le ComboBox et le SpinButton.
Mais, pour le fun (après tout, c’est l’objet de ce forum), poste ce qui te semblerait plus à ta convenance. Une fonction doit progresser, elle ne doit jamais rester figée ! Et moi, ça m'intéresse.