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

Excel Discussion :

Tester si le contenu d'une cellule est du texte ou une formule [XL-2003]


Sujet :

Excel

  1. #1
    Membre averti
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Avril 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2007
    Messages : 267
    Points : 350
    Points
    350
    Par défaut Tester si le contenu d'une cellule est du texte ou une formule
    Bonjour,

    Je rechercher une formule qui m'indique si une cellule contient du texte ou une formule.

    Exemple : je livre une feuille Excel qui contient en dernière colonne une formule de mise en forme de texte, cette formule donne une proposition que l'utilisation peut accepter (ne rien faire) ou écraser par un texte qui lui convient.
    Dans la colonne qui précéde, je voudrais pouvoir tester si l'utilisateur à effacer la formule par son texte ou bien laisser en l'état.
    Je ne ne trouve pas de formule sur le sujet.

    Par avance merci

  2. #2
    Membre régulier Avatar de Syphochaos
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    70
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2011
    Messages : 70
    Points : 112
    Points
    112
    Par défaut
    Bonjour blepy.

    Une idée qui m'est passée par la tête est de vérifier si le premier caractère est un "=" (donc une formule) ou non. Est-ce que celà te conviendrait ?

    Si oui, voici un lien qui devrait t'aider.

    Sypho.

  3. #3
    Membre averti
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Avril 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2007
    Messages : 267
    Points : 350
    Points
    350
    Par défaut
    La formule qui consisterait à tester si le premier caractère est un "égal" ne marche pas bien évidemment, puisque le test suivant teste le contenu résultat.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(GAUCHE(R2;1)="=";"";"Modifié")

  4. #4
    Membre averti
    Inscrit en
    Avril 2008
    Messages
    225
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Avril 2008
    Messages : 225
    Points : 447
    Points
    447
    Par défaut
    Bonjour blepy, Syphochaos, le forum

    Une manière de faire serait avec une fonction personnalisée :
    • Mettre ce code dans un module :
      Code : Sélectionner tout - Visualiser dans une fenêtre à part
      1
      2
      3
      Public Function EstUneFormule(cellule As Range) As Boolean
          EstUneFormule = cellule(1, 1).HasFormula
      End Function
    • L'utiliser de la manière suivante dans la feuille de calcul :
    La fonction renvoie un booléen :
    • True, si la cellule passée en paramètre contien une formule ;
    • False, dans le cas contraire.
    Il est don possible de l'utiliser au sein d'un SI(), ou tout autre formule normale.

    A+

  5. #5
    Membre averti
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Avril 2007
    Messages
    267
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2007
    Messages : 267
    Points : 350
    Points
    350
    Par défaut Le résultat est au rendez vous.
    Même si je sais programmer en VBA, je suis un adepte d'une recherche de solution en Excel pur (formule dans les feuilles) pour des problèmes de maintenabilité.

    Dans le cas présent, peu importe les moyens pourvu que cela marche merci bien

  6. #6
    Membre confirmé Avatar de Runsh63
    Homme Profil pro
    Contrôleur de gestion
    Inscrit en
    Mars 2011
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Contrôleur de gestion
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2011
    Messages : 476
    Points : 478
    Points
    478
    Par défaut
    Bonjour,

    Sans passer par VBA et via une formule, je n'ai pas de solution à proposer. Maintenant, un moyen simple de retrouver les cellules contenant une formule consiste à sélectionner la plage à tester puis Ctrl+T, sélectionner "Formule" et voilà. "Yapluka" mettre en couleur, ou je ne sais quoi encore qui te permettra de retrouver facilement tes cellules à formule.

  7. #7
    Expert éminent
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Points : 6 699
    Points
    6 699
    Par défaut
    Bonjour,

    Dans une cellule adjacente, tu peux utiliser cette macro XL4 qui retournera la formule ou le contenu, donc tu sais au premier coup d’œil ce qui a été choisi....

    cordialement,

    Didier

  8. #8
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 921
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 921
    Points : 28 907
    Points
    28 907
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Toujours avec la formule MacroXL4. LIRE.CELLULE(48;cellule) renvoie VRAI si c'est une formule, FAUX si c'est une constante.

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

Discussions similaires

  1. [XL-2010] Insérer une forme géométrique avec texte dans une cellule excel
    Par stephJP dans le forum Excel
    Réponses: 2
    Dernier message: 23/05/2014, 09h31
  2. Identifier une partie d'un text dans une cellule
    Par markinho04 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 25/09/2010, 16h21
  3. Centrer une image et un texte dans une cellule
    Par gaya102 dans le forum Mise en page CSS
    Réponses: 14
    Dernier message: 04/09/2009, 17h09
  4. Réponses: 14
    Dernier message: 14/11/2008, 10h16
  5. Réponses: 3
    Dernier message: 16/10/2007, 16h25

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