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 :

Fonction séparant une chaîne de caractères [XL-2000]


Sujet :

Macros et VBA Excel

  1. #1
    Membre à l'essai
    Ingénieur développement logiciels
    Inscrit en
    Mai 2009
    Messages
    28
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2009
    Messages : 28
    Points : 15
    Points
    15
    Par défaut Fonction séparant une chaîne de caractères
    Bonjour à tous,

    je suis à la recherche d'une fonction qui va lire une chaîne de caractères, s'arrêter à un point particulier de la chaîne (qui sera défini comme argument de la fontion) et ne garder que ce qu'il se trouve après ce point particulier.

    ex: J'ai cette chaîne: "p_css_emc35b_data.table_emc35b.aratx01[1]".
    Je veux ne garder que cette partie de la chaîne "table_emc35b.aratx01[1]".

    Merci à tous.

  2. #2
    Membre expérimenté
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Points : 1 580
    Points
    1 580
    Par défaut
    Bonjour,
    Si x est la position et si le texte est en A1, la formule suivante devrait donner satisfaction :

  3. #3
    Membre à l'essai
    Ingénieur développement logiciels
    Inscrit en
    Mai 2009
    Messages
    28
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2009
    Messages : 28
    Points : 15
    Points
    15
    Par défaut
    Oui seulement l'exemple ne décrit pas tout car je dois appliquer la fonction à plusieurs cas en même temps.

    Ce qui veut dire que je cherche qqch du type:
    chaine_en_cours=fonction(chaine_en_cours amputée d'une partie d'elle même)

    EDIT:
    Plus concrêtement, si je reprend mon exemple, je veux pouvoir scruter toute ma chaîne jusqu'au premier "." et à partir de là effacer tout ce qu'il se trouve avant y compris le dit "."

  4. #4
    Membre expérimenté
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Points : 1 580
    Points
    1 580
    Par défaut
    Pas de problème pour imbriquer les fonctions.
    Par exemple, pour prendre tout ce qui suit le premier point :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =STXT(A1;CHERCHE(".";A1)+1);NBCAR(A1))

  5. #5
    Membre à l'essai
    Ingénieur développement logiciels
    Inscrit en
    Mai 2009
    Messages
    28
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2009
    Messages : 28
    Points : 15
    Points
    15
    Par défaut
    Le compilateur n'aime pas les ";" pour combiner les fonctions.

    EDIT:

    Je propose:
    sVarTitle = STXT(sVarTitle, CHERCHE(".", sVarTitle + 1), NBCAR(sVarTitle))

  6. #6
    Membre expérimenté
    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    673
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Juin 2007
    Messages : 673
    Points : 1 580
    Points
    1 580
    Par défaut
    Attention, ce que je proposais est une formule à mettre dans une cellule, pas du code VBA !
    Pour faire la même chose dans une macro, la ligne de code est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sVarTitle = Mid(sVarTitle, InStr(sVarTitle, ".") + 1, Len(sVarTitle))

  7. #7
    Membre à l'essai
    Ingénieur développement logiciels
    Inscrit en
    Mai 2009
    Messages
    28
    Détails du profil
    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Mai 2009
    Messages : 28
    Points : 15
    Points
    15
    Par défaut
    Ouai exact, tout marche ! Merci bcp.

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

Discussions similaires

  1. Réponses: 8
    Dernier message: 12/02/2013, 01h08
  2. [Batch] Déplacer un fichier en fonction d'une chaîne de caractères
    Par Mantrin dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 08/06/2012, 09h47
  3. Fonction renvoyant une chaîne de caractères
    Par romain_t dans le forum C
    Réponses: 3
    Dernier message: 17/02/2011, 18h23
  4. Fonction retournant une chaîne de caractères
    Par lamyruth dans le forum C
    Réponses: 2
    Dernier message: 04/01/2010, 10h58
  5. Réponses: 5
    Dernier message: 15/02/2005, 18h07

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