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 :

Remplir cellule d'une colonne en fonction de suite de caractères autre colonne


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2020
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Transports

    Informations forums :
    Inscription : Octobre 2020
    Messages : 1
    Par défaut Remplir cellule d'une colonne en fonction de suite de caractères autre colonne
    Bonjour à tous,
    je dispose d'un fichier Excel, j'ai de nombreuses lignes. Dans la seconde colonne (B) j'ai des chaînes de caractères. Dans la troisième colonne (C) je veux pouvoir remplir par "True" ou "False"
    les cellules en fonction de la présence ou non de différentes succession de caractères dans les cellules de la seconde colonne. Un exemple:
    en B2 j'ai la chaine de caractère suivante: v150_cold_yellow. Je veux que toutes les cellules ayant la suite de caractères "cold" à l'intérieure de leur chaîne de caractères aient pour valeur
    "True" en troisième colonne. C'est la difficulté je pense ici, remplir par macro ou formule classique en se basant non pas sur toute la chaîne, mais sur une succession de caractères présents dans
    cette chaîne. J'espère que mes explications sont assez claires, si ce n'est pas le cas je reformulerai, merci d'avance pour votre aide !
    Cordialement,
    RS

  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 176
    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 176
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Nul besoin d'utiliser une procédure VBA pour obtenir ce que vous avez expliqué.

    Il existe nativement dans Excel, deux fonctions (CHERCHE et TROUVE) renvoyant la position d'uns sous-chaine dans une chaine ou #VALEUR! si celle-là n'existe pas. TROUVE est sensible à la casse, l'autre pas

    Ainsi en reprenant votre exemple CHERCHE("Cold";B2) renverra 6 si B2 contient "v150_cold_yellow" ou #VALEUR! si Cold n'est pas présente dans la chaîne B2

    La fonction ESTERREUR renvoie VRAI si son argument Valeur renvoie une erreur et FAUX dans le cas contraire
    La fonction NON inverse une valeur booléeene

    donc la lormule complète ci-dessous renverra VRAI ou FAUX suivant que la sous-chaine Cold est présente ou pas dans la cellule B2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =NON(ESTERR(CHERCHE("Cold";B2)))
    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
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    bonjour
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub testtt()
    For i = 2 To Cells(Rows.Count, 2).End(xlUp).Row
    If Cells(i, 2) Like "*cold*" Then Cells(i, 3) = "True"
    Next i
    End Sub

Discussions similaires

  1. [XL-2013] Déplacer plusieurs cellules d'une colonne en fonction d'une date
    Par clafouty dans le forum Excel
    Réponses: 6
    Dernier message: 14/07/2015, 19h45
  2. Réponses: 3
    Dernier message: 14/09/2014, 01h03
  3. [XL-2010] supprimer des lignes en fonction de la valeur de la cellule d'une colonne
    Par psylo24 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 28/11/2012, 13h09
  4. Réponses: 1
    Dernier message: 05/03/2012, 15h04
  5. Réponses: 2
    Dernier message: 17/03/2011, 21h45

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