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 :

Tronquer la fin d'une chaine de caractere


Sujet :

Excel

  1. #1
    Membre régulier
    Inscrit en
    Septembre 2002
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 200
    Points : 120
    Points
    120
    Par défaut [Resolu] Tronquer la fin d'une chaine de caractere
    Bonjour, je dispose de cette cellule qui contient le texte :

    /STD/DATA_ENGINE/TARGET_PC_HARD_ELIOS/A429 DATA

    Quelle formule faire pour écrire dans la cellule voisine A429 DATA, c'est a dire extraire tout ce qui se trouve après "/" ?

    J'ai bien essayé avec "DROITE()" mais il faudrait que j'arrive à retrouver le numéro du dernier "/" dans la chaine.

    Merci pour l'aide.

  2. #2
    Membre éclairé

    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    791
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 791
    Points : 688
    Points
    688
    Par défaut
    pour trouver le dernier emplacement d'un caractere, tu peux passer par une formule matricielle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =MAX(IF(MID(A1;ROW(INDIRECT("z1:z"&LEN(A1)));1)="/";ROW(INDIRECT("z1:z"&LEN(A1)));""))
    (attentin, la formule est en anglais, si ton excel est en francais, il faututiliser les nom de fonction fr)
    a valider par Ctrl + maj + enter

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ROW(INDIRECT("z1:z"&LEN(A1)))
    permet de generer une "variable" qui va aller de 1 la fin de ta chaine.

    Ensuite, grace au matriciel, on va regarder chaque lettre de la chaine (de la 1 a la derniere, en utilisant la "variable") et si c'est égal a "/"; alors on affiche l'emplacement (la "variable") et sinon on met le vide. Ensuite on prend le maximum et on a le dernier emplacement de "/"

    si tu veux des explications plus détaillées n'hésite pas a demander

  3. #3
    Membre régulier
    Inscrit en
    Septembre 2002
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 200
    Points : 120
    Points
    120
    Par défaut
    Merci beaucoup pour la réponse

    Imaginons que ma chaine /STD/DATA_ENGINE/TARGET_PC_HARD_ELIOS/A429 DATA soit dans la cellule C66, j'ai essayé avec cette formule (excel français) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =MAX(SI(STEXT(C66;LIGNE(INDIRECT("z1:z"&NBCAR(C66)));1)="/";LIGNE(INDIRECT("z1:z"&NBCAR(C66)));""))
    Et ca me renvoie #NOM?

    Par ailleurs je ne comprends pas trop le sens de "z1:z" ??

    Merci pour l'aide.

  4. #4
    Membre éclairé

    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    791
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 791
    Points : 688
    Points
    688
    Par défaut
    ligne() doit fonctionner avec soit une cellule, soit une plage de cellule (et ca restituer un nombre entier, correspondant au numéro de ligne)
    Comme moi je cherche une facon de parcourir ta chaine, ca va aller de la ligne 1 a la ligne NBCAR(C66)
    Et apres, j'ai mis une colonne pour faire la plage. J'ai pris Z mais tu peux prendre n'importe la quelle

    indirect permet de recomposer une plage a partir d'un texte. Supposons que nbcar(c66) vale 57, INDIRECT("z1:z"&NBCAR(C66)) ca donc valoir la plage Z1:Z57
    Et donc LIGNE(INDIRECT("z1:z"&NBCAR(C66))) validé en matriciel va donner de 1 a 57

    pour le #nom, c'est peut-etre qu'il y a un probleme de traduction,
    Sur le site que j'utilise pour la conversion fr/en pour les fonctions, il a l'air de penser que Mid c'est STXT et pas STEXT, tu es sur de la traduction? http://www.docmemo.com/office/excelfonctionsanfr.php

    Et bien valider la formule par ctrl + maj + enter (sinon tu auras #valeur comme résultat)

    Le truc c'est que je ne peux pas tester la formule en francais, mon excel ne la prendra pas
    J'ai testé la version anglaise avant de la poster, donc je suis sure du principe mais pas de la traduction

  5. #5
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Âge : 61
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 563
    Points : 1 691
    Points
    1 691
    Par défaut
    si je peux me permettre, ce que n'a pas compris muetdhiver, c'est que la formule ne lui renvoie pas la réponse qu'il attend (A429DATA) mais la position du dernier / c'est a dire 38, il faut rajouter la fonction droite
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    =DROITE(A1;NBCAR(A1)-MAX(SI(STXT(A1;LIGNE(INDIRECT("z1:z"&NBCAR(A1)));1)="/";LIGNE(INDIRECT("z1:z"&NBCAR(A1)));"")))
    Bon week end

  6. #6
    Membre éclairé

    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    791
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 791
    Points : 688
    Points
    688
    Par défaut
    ah oui, effectivement
    J'aurai du préciser, désolée

  7. #7
    Membre régulier
    Inscrit en
    Septembre 2002
    Messages
    200
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 200
    Points : 120
    Points
    120
    Par défaut
    Merci bcp pour toutes vos explications qui m'ont permis de faire ce que je voulais !
    Vous etes des pro des formules d'excel !

    Encore merci.

Discussions similaires

  1. [Débutant] Modification de la fin d'une chaine de caracteres
    Par wwwided dans le forum VB.NET
    Réponses: 5
    Dernier message: 18/09/2013, 10h20
  2. Ajouter des espaces à la fin d'une chaine de caracteres
    Par kodo dans le forum Général Java
    Réponses: 1
    Dernier message: 22/04/2011, 11h25
  3. Retirer les espaces à la fin d'une chaine de caracteres
    Par laurentdepibrac dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 18/06/2009, 14h39
  4. Réponses: 11
    Dernier message: 05/11/2007, 14h38
  5. ajouter une chaine de caractere en fin de ligne
    Par parano dans le forum Langage
    Réponses: 2
    Dernier message: 05/04/2007, 18h42

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