Formule dans VBA avec variable
Résolu
SF-TU
Messages postés
18
Date d'inscription
Statut
Membre
Dernière intervention
-
SF-TU Messages postés 18 Date d'inscription Statut Membre Dernière intervention -
SF-TU Messages postés 18 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Je voudrais insérer une formule dans une macro qui intègrerait une variable.
La variable est nommée plus haut dans ma Macro :
... Dim HArrivM As Date
HArrivM = Workbooks("Calcul et suivi RTT.xlsm").Worksheets("Semaine Type").Range("B3").Value
sachant que B3 = 08:30
La formule est la suivante :
ActiveCell.FormulaR1C1 = "=IF((OR(RC[9]=1,RC[9]=2)),HArrivM,"""")"
Le résultat qui s'affiche est #NOM? et non 08:30. Pourquoi ?
Pouvez-vous m'aider à solutionner mon problème ?
En vous remerciant,
Bien cordialement
Aurélie Rocheteau
Je voudrais insérer une formule dans une macro qui intègrerait une variable.
La variable est nommée plus haut dans ma Macro :
... Dim HArrivM As Date
HArrivM = Workbooks("Calcul et suivi RTT.xlsm").Worksheets("Semaine Type").Range("B3").Value
sachant que B3 = 08:30
La formule est la suivante :
ActiveCell.FormulaR1C1 = "=IF((OR(RC[9]=1,RC[9]=2)),HArrivM,"""")"
Le résultat qui s'affiche est #NOM? et non 08:30. Pourquoi ?
Pouvez-vous m'aider à solutionner mon problème ?
En vous remerciant,
Bien cordialement
Aurélie Rocheteau
A voir également:
- Formule dans VBA avec variable
- Formule si et - Guide
- Formule moyenne excel plusieurs colonnes - Guide
- Formule mathématique - Télécharger - Études & Formations
- Formule somme excel colonne - Guide
- Excel mise en forme conditionnelle formule - Guide
12 réponses
Bonjour
Essaies ceci
f = "=IF((OR(RC[9]=1,RC[9]=2))," & HArrivM & ","""")"
ActiveCell.FormulaR1C1 = f
Cdlmnt
Essaies ceci
f = "=IF((OR(RC[9]=1,RC[9]=2))," & HArrivM & ","""")"
ActiveCell.FormulaR1C1 = f
Cdlmnt
Bonjour ccm81
Merci mais le code ne marche pas.
Je vous donne le code en entier mais il fait appel à une feuille de planning mensuel.
Merci d'avance de voir si vous pouvez y faire quelque chose.
Cdt
Merci mais le code ne marche pas.
Je vous donne le code en entier mais il fait appel à une feuille de planning mensuel.
Merci d'avance de voir si vous pouvez y faire quelque chose.
Cdt
Bonjour ccm81, ça ne marche pas non plus.
La valeur de HArrivM est bien enregistrée, f également se met bien en mémoire mais ça plante à la ligne ActiveCell.FormulaR1C1=f
"erreur définie par l'application ou par l'objet"
Je met tout le code même si c'est difficilement buvable! :-)
Le problème se situe dans l'utilisation de variable (HArrivM) dans la formule. Mais je ne vois pas où est l'erreur...
La valeur de HArrivM est bien enregistrée, f également se met bien en mémoire mais ça plante à la ligne ActiveCell.FormulaR1C1=f
"erreur définie par l'application ou par l'objet"
Je met tout le code même si c'est difficilement buvable! :-)
Sub FusionFeuillesPrésence() ' ' ' permet de fusionner les feuilles de présence pour RTT avec les horaires et spécificités du salarié ' Recupération des données NomSalarie = Range("A1").Value Annee1 = Range("J2").Value Annee2 = Range("J3").Value Dim HArrivM As Date HArrivM = Workbooks("Calcul et suivi RTT.xlsm").Worksheets("Semaine Type").Range("B3").Value ' Ouvrir le fichier générale des Feuilles de présence pour RTT Workbooks.Open Filename:= _ "T:\Ressources Humaines\Suivi des Parcours\Feuilles de présence\Feuilles de présence pour RTT " & Annee1 & "-" & Annee2 & ".xlsm" ' Enregistrer le fichier au nom du Salarié ChDir "T:\Ressources Humaines\Suivi des Parcours\Feuilles de présence" ActiveWorkbook.SaveAs Filename:= _ "T:\Ressources Humaines\Suivi des Parcours\Feuilles de présence\Feuilles de présence pour RTT " & Annee1 & "-" & Annee2 & " " & NomSalarie & ".xlsm" _ , FileFormat:=xlOpenXMLWorkbookMacroEnabled, CreateBackup:=False ' Copier le nom et le service du salarié Sheets(Array("JUIN", "JUILLET", "AOÛT", "SEPTEMBRE", "OCTOBRE", "NOVEMBRE", _ "DÉCEMBRE", "JANVIER", "FÉVRIER", "MARS", "AVRIL", "MAI")).Select Sheets("JUIN").Activate Windows("Calcul et suivi RTT.xlsm").Activate Range("A1").Copy Windows("Feuilles de présence pour RTT " & Annee1 & "-" & Annee2 & " " & NomSalarie & ".xlsm").Activate Range("I3:O3").Select ActiveSheet.Paste Windows("Calcul et suivi RTT.xlsm").Activate Range("C1").Copy Windows("Feuilles de présence pour RTT " & Annee1 & "-" & Annee2 & " " & NomSalarie & ".xlsm").Activate Range("I4:O4").Select ActiveSheet.Paste 'Dissocier les feuilles Sheets(2).Activate Sheets(1).Select Range("A9").Select ' Insérer les formules ' Faire la manip pour chaque feuille Dim k As Integer, i As Integer k = Sheets.Count For i = 1 To k Sheets(i).Activate Range("A9").Select 'Insérer les formules jusqu'à ce que la case A9 soit vide Do Until ActiveCell.Value = "" 'Pour chaque jour de la semaine du lundi au samedi If ActiveCell.Value = "Lundi" And ActiveCell.Offset(0, 2) = "" _ Or ActiveCell.Value = "Mardi" And ActiveCell.Offset(0, 2) = "" _ Or ActiveCell.Value = "Mercredi" And ActiveCell.Offset(0, 2) = "" _ Or ActiveCell.Value = "Jeudi" And ActiveCell.Offset(0, 2) = "" _ Or ActiveCell.Value = "Vendredi" And ActiveCell.Offset(0, 2) = "" _ Or ActiveCell.Value = "Samedi" And ActiveCell.Offset(0, 2) = "" Then 'Insérer la formule de Arrivée Matin ActiveCell.Offset(0, 2).Select ActiveCell.FormulaR1C1 = "=IF((OR(RC[9]=1,RC[9]=2)),HArrivM, """")" Selection.HorizontalAlignment = xlCenter Loop Next i ....... Suite du code End Sub
Le problème se situe dans l'utilisation de variable (HArrivM) dans la formule. Mais je ne vois pas où est l'erreur...
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Ici ça fonctionne
https://www.cjoint.com/?3FspWarh3YQ
As tu bien respecté la syntaxe
RQ. Que penses tu de la remarque de michel?
Cdlmnt
https://www.cjoint.com/?3FspWarh3YQ
As tu bien respecté la syntaxe
RQ. Que penses tu de la remarque de michel?
Cdlmnt
Bonjour,
Je viens d'essayer ton fichier, ccm81 et en effet ça marche mais ma variable HArrivM est une "date" ou plutôt un horaire de début ou fin de journée (exemple 08:30).
Alors si je mets dans ton fichier : Dim HArrivM as Date alors une fois arrivé à la formule, VBA dit "Erreur défini par l'application ou par l'objet".
Je pense que cela vient du format de ma variable qu'il ne veut pas prendre en compte.
Qu'en pensez-vous ?
Merci
Cdt
Je viens d'essayer ton fichier, ccm81 et en effet ça marche mais ma variable HArrivM est une "date" ou plutôt un horaire de début ou fin de journée (exemple 08:30).
Alors si je mets dans ton fichier : Dim HArrivM as Date alors une fois arrivé à la formule, VBA dit "Erreur défini par l'application ou par l'objet".
Je pense que cela vient du format de ma variable qu'il ne veut pas prendre en compte.
Qu'en pensez-vous ?
Merci
Cdt
Essaie en déclarant
Dim HArrivM as Double
ou
Dim HArrivM as Long
https://www.cjoint.com/?3FsqDURJRKU
Dim HArrivM as Double
ou
Dim HArrivM as Long
https://www.cjoint.com/?3FsqDURJRKU
Je suis désolée mais il doit y avoir un truc que je ne comprends pas car même avec ton fichier, si à la place de la date, je mets 08:30, le VBA ouvre une fenêtre d'erreur avec le chiffre 400 et une croix dans un rond rouge.
Je ne sais pas ce que cela signifie.
Merci, cdt
Je ne sais pas ce que cela signifie.
Merci, cdt
Bonjour,
Parce que les valeurs à tester (si =1 ou =2) ne sont pas encre renseignées. C'est quand la personne va saisir 1 ou 2 dans une cellule que la formule va s'appliquer.
On ne fait pas de vba pour ça...
On teste la cellule, si elle est vide on ne met rien, si ok on évalue la formule :
=si(A2="";"";ta_formule)
eric
Parce que les valeurs à tester (si =1 ou =2) ne sont pas encre renseignées. C'est quand la personne va saisir 1 ou 2 dans une cellule que la formule va s'appliquer.
On ne fait pas de vba pour ça...
On teste la cellule, si elle est vide on ne met rien, si ok on évalue la formule :
=si(A2="";"";ta_formule)
eric
Effectivement ça ne fonctionne pas
Une solution (pas jolie mais qui semble fonctionner)
https://www.cjoint.com/?3FstdccAEsn
@eric, salut à toi
je ne crois pas que le problème vienne de là, si la formule était bonne ça donnerait un message d'erreur de la feuille et non de la part de vba
il y a un problème au niveau de la fabrication de la formule, avec HArrivM entier (date) ça fonctionne, mais avec HArrivM décimal (heure) ça coince
je fais appel à tes lumières
Une solution (pas jolie mais qui semble fonctionner)
https://www.cjoint.com/?3FstdccAEsn
@eric, salut à toi
je ne crois pas que le problème vienne de là, si la formule était bonne ça donnerait un message d'erreur de la feuille et non de la part de vba
il y a un problème au niveau de la fabrication de la formule, avec HArrivM entier (date) ça fonctionne, mais avec HArrivM décimal (heure) ça coince
je fais appel à tes lumières
Je crois que c'était un problème au niveau des "virgules et "point-virgule".
En passant au format local, ça fonctionne
f = "=SI(OU(LC(9)=1;LC(9)=2);" & HArrivM & ";"""")"
https://www.cjoint.com/?3Fst1tnap6S
Cdlmnt
En passant au format local, ça fonctionne
f = "=SI(OU(LC(9)=1;LC(9)=2);" & HArrivM & ";"""")"
https://www.cjoint.com/?3Fst1tnap6S
Cdlmnt