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

Résolu
mod77 Messages postés 1284 Date d'inscription   Statut Membre Dernière intervention   -  
mod77 Messages postés 1284 Date d'inscription   Statut Membre Dernière intervention   -
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 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Bonjour
essaye avec une virgule
Range("A4").Formula = "=COUNTIFS(A6:A156,""VRAI"")"


Cordialement, 
Jordane                                                                 
1
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
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 1284 Date d'inscription   Statut Membre Dernière intervention   53
 
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 8561 Date d'inscription   Statut Membre Dernière intervention   1 780
 
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 1284 Date d'inscription   Statut Membre Dernière intervention   53 > Patrice33740 Messages postés 8561 Date d'inscription   Statut Membre Dernière intervention  
 
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