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

Macros et VBA Excel Discussion :

Ecrire une formule SI dans une cellule à l'aide d'une macro.


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    travailleur
    Inscrit en
    Juillet 2018
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : travailleur

    Informations forums :
    Inscription : Juillet 2018
    Messages : 76
    Par défaut Ecrire une formule SI dans une cellule à l'aide d'une macro.
    Bonjour,

    J'ai besoin de votre aide car je sèche malgré mes recherches.
    J'ai un fichier excel où il y a pas mal de cellules avec des valeurs données par des fonctions SI qui vont chercher des valeurs ailleurs. Quand cela ne fonctionne pas, il faut venir écrire les valeurs à la main, c'est pour cela que la cellule n'est pas protégée.
    J'aurais besoin d'une macro qui permette de remettre les formules dans les cases.

    Par exemple en D10, j'ai besoin d'écrire la fonction Si="HT"; P10; R10"

    MErci d'avance.

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par Guizmonster Voir le message
    J'aurais besoin d'une macro qui permette de remettre les formules dans les cases.
    Quelles formules dans quelles cases ?

    Par exemple en D10, j'ai besoin d'écrire la fonction Si="HT"; P10; R10"
    Il manque un élément dans ta formule, entre le "Si" et le "=" : qu'est-ce qui est comparé à "HT" ?

  3. #3
    Membre confirmé
    Homme Profil pro
    travailleur
    Inscrit en
    Juillet 2018
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : travailleur

    Informations forums :
    Inscription : Juillet 2018
    Messages : 76
    Par défaut
    Citation Envoyé par Menhir Voir le message
    Quelles formules dans quelles cases ?


    Il manque un élément dans ta formule, entre le "Si" et le "=" : qu'est-ce qui est comparé à "HT" ?
    Bonjour menhir,

    La formule, qui se trouve pour cet exemple en D7, est =Si(B7="HT"; P10; R10)
    J'avais écrit rapidement désolé.
    Une fois que j'ai le code, je pourrais le faire pour chaque cellule. Mais c'est une variante, toujours de fonction SI, de celle que j'ai mise. En gros je lis le texte de la cellule et j'affiche la valeur en fonction.

    Bien cordialement

  4. #4
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par Guizmonster Voir le message
    La formule, qui se trouve pour cet exemple en D7, est =Si(B7="HT"; P10; R10)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("D7").LocalFormula = "=SI(B7=""HT""; P10; R10)"
    Une fois que j'ai le code, je pourrais le faire pour chaque cellule.
    Si tu dois le faire cellule par cellule, j'espère pour toi que tu n'en as pas beaucoup.
    Sinon ça risque d'être très fastidieux.

  5. #5
    Membre confirmé
    Homme Profil pro
    travailleur
    Inscrit en
    Juillet 2018
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : travailleur

    Informations forums :
    Inscription : Juillet 2018
    Messages : 76
    Par défaut
    Quand je prends ta formule et que j'exécute la macro, j'ai une erreur 438.

    Edit: en passant par de la fonction IF, j'arrive à mes fins.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Range("D7").Formula = "=SI(B7=""HT"", P10, R10)"

  6. #6
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    J'ai fait une erreur d'inattention : le nom de la méthode n'est pas LocalFormula mais FormulaLocal.

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

Discussions similaires

  1. [XL-2003] Probléme pour ecrire une macro avec Combobox et incrementation dans plusieurs colonne
    Par mimil49 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 06/07/2011, 10h28
  2. Réponses: 3
    Dernier message: 23/04/2010, 18h06
  3. Ecrire une macro IMACRO
    Par triaguae dans le forum Firefox
    Réponses: 3
    Dernier message: 09/12/2008, 18h43
  4. [VBA-E] m'aider a ecrire une macro Excel?
    Par PASCAL33 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 10/05/2006, 08h59
  5. Réponses: 17
    Dernier message: 08/01/2006, 19h05

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