Erreur #NOM? sur Range().formula avec NB.SI.ENS

Résolu/Fermé
mod77 Messages postés 1273 Date d'inscription vendredi 10 juillet 2009 Statut Membre Dernière intervention 14 janvier 2024 - 14 juin 2017 à 10:29
mod77 Messages postés 1273 Date d'inscription vendredi 10 juillet 2009 Statut Membre Dernière intervention 14 janvier 2024 - 14 juin 2017 à 14:40
Bonjour,

J'ai voulu entrer la formule ci après dans mon code vba, pour compter le nombre de "VRAI" présents dans ma colonne "A" :
 Range("A4").Formula = "=NB.SI.ENS(A6:A156";""VRAI"")" 


mais j'ai eu une erreur 1004. Alors j'ai cherché l'équivalent anglais:
Range("A4").Formula = "=COUNTIFS(A6:A156;""VRAI"")


mais maintenant j'ai: #NOM? affiché en A4 et je ne comprends pas pourquoi.

Quelqu'un peut-il m'aider svp?



1 réponse

jordane45 Messages postés 38144 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 21 avril 2024 4 650
Modifié le 14 juin 2017 à 14:35
Bonjour
essaye avec une virgule
Range("A4").Formula = "=COUNTIFS(A6:A156,""VRAI"")"


Cordialement, 
Jordane                                                                 
1
jordane45 Messages postés 38144 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 21 avril 2024 4 650
14 juin 2017 à 10:34
Et puis.. sinon tu peux utiliser le FormulaLocal au lieu de Formula pour le mettre en français...
https://docs.microsoft.com/fr-fr/office/vba/api/excel.range.formulalocal?redirectedfrom=MSDN
0
mod77 Messages postés 1273 Date d'inscription vendredi 10 juillet 2009 Statut Membre Dernière intervention 14 janvier 2024 53
14 juin 2017 à 13:06
Bonjour jordan45,

Merci pour la virgule !
Mais maintenant la formule s'affiche en clair dans la cellule comme un texte mais ne s'exécute pas!

une autre idée?
0
Patrice33740 Messages postés 8556 Date d'inscription dimanche 13 juin 2010 Statut Membre Dernière intervention 2 mars 2023 1 775
Modifié le 14 juin 2017 à 14:28
Bonjour,

Attention VRAI peut être soit un texte, soit un booléen !!!
Lorsqu'on saisit Vrai dans une cellule au format Standard, Excel le convertit automatiquement en booléen (idem pour Faux).
Lorsqu'on saisit Vrai dans une cellule déjà au format Texte, Vrai reste du texte.

De plus, le fait de changer de format de cellule (Standard vers Texte ou inversement) ne change pas la donnée qu'elle contient déjà : un booléen reste un booléen et un texte reste un texte.

Comment faire la différence :
- mettre la cellule en alignement horizontal Standard (pas droite, pas gauche, pas centré)
- élargir la colonne : les booléens sont toujours centrés et en majuscule, les textes sont alignés à gauche et conservent la casse dans laquelle ils ont été saisis.

Pour du texte :
Range("A4").NumberFormatLocal = "Standard"
Range("A4").FormulaLocal = "=NB.SI.ENS(A6:A156;""VRAI"")"
Pour des booléens :
Range("A4").NumberFormatLocal = "Standard"
Range("A4").FormulaLocal = "=NB.SI.ENS(A6:A156;VRAI)"


PS : si il n'y a qu'un critère, employer NB.SI() au lieu de NB.SI.ENS()
0
mod77 Messages postés 1273 Date d'inscription vendredi 10 juillet 2009 Statut Membre Dernière intervention 14 janvier 2024 53 > Patrice33740 Messages postés 8556 Date d'inscription dimanche 13 juin 2010 Statut Membre Dernière intervention 2 mars 2023
14 juin 2017 à 14:40
Alors là chapeau bas ! Merci beaucoup Patrice33740!

Là, je ne pouvais pas trouver seul j'en était encore à torturer ces formules:

'Range("A4").Value = Application.WorksheetFunction.CountIfs(Worksheets("Presence").Range("A6:A156"), "VRAI")
'Range("A4").Value = Worksheets("Presence").Range("A:A").Find(what:="VRAI", lookat:=xlWhole)

sans résultat hormis un zéro pour la 1ere.

Youpi :-)) je peux aller manger maintenant

merci beaucoup et à jordane45 aussi
0