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 :

Si cellule contient un mot alors appliquer cette formule


Sujet :

Excel

  1. #1
    Membre confirmé
    Homme Profil pro
    DBA Oracle
    Inscrit en
    Mai 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DBA Oracle

    Informations forums :
    Inscription : Mai 2006
    Messages : 166
    Par défaut Si cellule contient un mot alors appliquer cette formule
    Bonsoir, j'ai besoin d'une fonction qui selon un mot dans une cellule je puisse executer une formule specifique :

    Si la cellule C1 contient "Valeur1" alors je multiplie par -1 le contenu de la cellule F1
    Si la cellule C1 contient "Valeur2" alors je multiplie par +2 le contenu de la cellule F1
    Si la cellule C1 contient "Valeur3" alors je multiplie par -1 le contenu de la cellule F1

    Merci

  2. #2
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 114
    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 : 13 114
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Pour savoir si un mot se trouve dans une chaîne de caractères, il existe deux fonctions de la catégorie Texte. Il s'agit des fonctions TROUVE et CHERCHE. La première est sensible à la casse, l'autre non.

    Dans l'exemple ci-dessous, la fonction CHERCHE renverra 4
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =CHERCHE("name";"My Name is Nobody")
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  3. #3
    Membre Expert Avatar de QuestVba
    Homme Profil pro
    Enseignant
    Inscrit en
    Juillet 2012
    Messages
    2 475
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Belgique

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Service public

    Informations forums :
    Inscription : Juillet 2012
    Messages : 2 475
    Par défaut
    Salut,
    Pour moi, j'utiliserais cette formule pour trouver une correspondance exacte :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(OU(NB.SI(C1;"Valeur1")>0;NB.SI(C1;"Valeur3")>0);F1*-1;SI(NB.SI(C1;"Valeur2")>0;F1*2;""))
    J'étais parti sur la même proposition que Philippe mais comme je ne connais pas la façon dont les données sont encodées, il y a un risque. Avec CHERCHE, si je cherche Valeur1 et que la cellule contient Valeur145, je vais avoir un faux positif.

  4. #4
    Membre confirmé
    Homme Profil pro
    DBA Oracle
    Inscrit en
    Mai 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DBA Oracle

    Informations forums :
    Inscription : Mai 2006
    Messages : 166
    Par défaut
    En fait je recherche cela pour calculer automatiquement des plus ou moins values de crypto monnaie. L'état que je reçois ressemble à l'image ci-jointe.

    J'ai besoin d'additionner ou de soustraire des données de sorte à afficher un capital restant.
    Ainsi sur ma plateforme d'Exchange ici Swissborg, si je dépose des euros ("Deposit") ou que j'achète une crypto monnaie ("Buy") pour une valeur de 100 euro cette donnée sera positive donc je ne la touche pas, ce sera donc des données à additionner. Pour cela je recopie telle quelle la valeur dans la colonne Achat/vente.

    Par contre, si je fais un envoi ("Withdrawal") de crypto monnaie ou que j'échange ("Sell") une crypto monnaie contre une autre ou que je retire des euros est une information à soustraire au capital restant.

    Alors j'ai réussi avec cette formule : =(SI(C10="Deposit";1;SI(C10="Withdrawal";-1;0))*J10) à le faire pour deux valeurs (Deposit et withdrawal) mais je coince pour le faire avec les autres le "Buy" et le "Sell".

    Voilà merci pour votre aide

    Nom : Extrait Swissborg.png
Affichages : 10508
Taille : 99,1 Ko
    Images attachées Images attachées  

  5. #5
    Membre confirmé
    Homme Profil pro
    DBA Oracle
    Inscrit en
    Mai 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DBA Oracle

    Informations forums :
    Inscription : Mai 2006
    Messages : 166
    Par défaut
    Merci pour votre aide, vos exemples m'ont donné des idees et la solution que j'ai trouvé est finalement avec les valeurs A, B, C, D respectivement pour 1, 1, -1 et -1 du coup le NB.SI prendrait tout son sens non ?

    Code formule : Sélectionner tout - Visualiser dans une fenêtre à part
    =SI(OU(D8="A";D8="B");1;SI(OU(D8="C";D8="D");-1;1))

    Qu'en pensez vous ?

    En fait c'est pas genial car j'ai une nouvelle valeur qui vient d'apparaitre c'est "Yeald Earnings" qui correspond a une valeur postitive, du coup je e rends compte que ma solution n'est pas evolutive. Ce qui serait bien ce serait de pouvoir modifier les mots cles facilement, par exemple je pourrais mettre dans une cellule une liste de mots : liste1= (AA, BB, CC, DD etc etc) pour une valeur positive et une autre liste liste2=(EE, FF, GG, HH etc ...) pour des valeurs negatives et ainsi faire une formule du genre si ma valeur est dans liste1 alors je multipli par 1 et si c'est dans liste2 je multiplie par - 1

  6. #6
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 114
    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 : 13 114
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    D'après vos explications, je travaillerais plutôt avec une table de correspondance en utilisant la fonction RECHERCHEV ou INDEX combiné avec EQUIV.

    Voir exemple dans ce billet titré Comment remplacer des SI imbriqués par la fonction RECHERCHEV
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

Discussions similaires

  1. [Toutes versions] Si la cellule contient le mot alors
    Par yassine_13 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 28/02/2020, 10h28
  2. Comment savoir si une cellule contient un mot particulier?
    Par steelk dans le forum Macros et VBA Excel
    Réponses: 20
    Dernier message: 02/06/2017, 11h53
  3. si la cellule B6 contient tel mot alors C6="."
    Par facteur dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 13/08/2013, 14h55
  4. [XL-2003] Si la cellule contient un mot alors.
    Par facteur dans le forum Excel
    Réponses: 2
    Dernier message: 23/03/2012, 16h47
  5. [XL-2003] si la cellule contient un mot alors
    Par facteur dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 14/10/2010, 23h34

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