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 :

extraire une chaine a partir d'un caractere special jusqu'à un caractere special


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2016
    Messages : 61
    Par défaut extraire une chaine a partir d'un caractere special jusqu'à un caractere special
    Bonjour,

    Je veux extraire de ma cellule juste le nom d utilisateur
    Ma cellule ressemble à ça ;
    usr(C.MUNDT@VAT-SVN-042@0)
    et je veux extraire juste C.MUNDT
    Donc extraire à partir de "(" jusqu à @
    Est ce que vous qurez des idees ?
    merci

  2. #2
    Membre Expert Avatar de antonysansh
    Homme Profil pro
    Chargé d'études RH
    Inscrit en
    Mai 2014
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé d'études RH
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2014
    Messages : 1 115
    Par défaut
    Bonjour hs.hs,

    Les fonctions Excel TROUVE et STXT vont t'aider.

    =TROUVE("(";"usr(C.MUNDT@VAT-SVN-042@0)") va te donner la position de la première '('
    =TROUVE("@";"usr(C.MUNDT@VAT-SVN-042@0)") va te donner la position du premier '@'

    Ensuite =STXT(Texte; No_départ; No_car) va te donner ce que tu cherches.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =STXT(A1;TROUVE("(";A1)+1;TROUVE("@";A1)-TROUVE("(";A1)-1)
    Si le code est en A1

  3. #3
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    avec VBA, pour le cas où le résultat serait à utiliser dans une variable, sans passer par une autre cellule.
    Soit B2 (exemple) : la cellule contenant "usr(C.MUNDT@VAT-SVN-042@0)"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    toto = Split(Replace(Range("B2").Text, "(", "@"), "@")(1)
     MsgBox toto ' toto = "C.MUNDT"

  4. #4
    Membre actif
    Femme Profil pro
    Étudiant
    Inscrit en
    Juin 2016
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Finance

    Informations forums :
    Inscription : Juin 2016
    Messages : 61
    Par défaut
    Merci a vous tous

  5. #5
    Candidat au Club
    Homme Profil pro
    Chef projets secteur automobile
    Inscrit en
    Janvier 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Chef projets secteur automobile
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2019
    Messages : 3
    Par défaut Extraire chaînes de caractère à partir d'un caractère spécial
    Bonjour,

    Je suis un novice sur VBA et j'ai besoin de votre aide.

    J'ai un fichier excel obtenu à partir d'un fichier pdf; ce qui fait j'ai un fichier avec des lignes toutes sur une cellule.
    Exemple:
    ppaaap|fdkjfhd|bbbb|11111|3333|jfjfjfj
    tout dans une cellule.

    Je souhaite extraire chaque texte et/ou nombre (séparé les uns des autres exactement par le caractère "|") dans des colonnes les unes à coté des autres.
    Pour mieux comprendre:

    A1 = "ppaaap|fdkjfhd|bbbb|11111|3333|jfjfjfj"

    je veux avoir:
    B1= "ppaaap"
    C1= "fdkjfhd"
    D1= "bbbb"
    ......

    Pourriez-vous m'aider?
    Merci.

  6. #6
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour
    Accueil -->> Données --->> convertir
    ou (si depuis VBA) --->> Range.TextToColumns, méthode (rubrique de l'aide interne VBA)

  7. #7
    Nouveau candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2019
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 3
    Par défaut
    Bonjour à tous,
    Je suis un peu dans le même cas que Fabuleux sauf que ma chaîne de caractère ne provient pas d'un fichier PDF.

    J'ai une chaîne de caractère brute qui se présente de la façon suivante : "Dock code : ECHIROLLES - BAT C_Cross dock : _Routing : DP1_Replenish départ : E DP7_Replenish arrivée : G DP1_Lieu1 de conso : DP1 kit_Reverse log : "

    Je souhaite qu'à chaque "_" il prend les caractères situés avant, pour avoir dans chaque cellule :
    A1 = Dock code : ECHIROLLES - BAT C
    B1 = Cross dock :
    C1 = Routing : DP1
    D1 = Replenish départ : E DP7
    E1 = Replenish arrivée : G DP1
    F1 = Lieu1 de conso : DP1 kit
    G1 = Reverse log :

    Comment je peux faire ça avec une formule ou VBA ?
    Merci d'avance

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

Discussions similaires

  1. Extraire une chaine à partir d'un mot clé
    Par ouinih dans le forum PL/SQL
    Réponses: 3
    Dernier message: 19/10/2010, 09h25
  2. Extraire une chaine de caractere à partir d'un fichier
    Par Dalidou dans le forum Général Java
    Réponses: 11
    Dernier message: 10/06/2009, 22h04
  3. Extraire une chaine de caratere
    Par matthieu5978 dans le forum Langage
    Réponses: 2
    Dernier message: 15/12/2005, 19h52
  4. [RegEx] Extraire une chaine
    Par pierre50 dans le forum Langage
    Réponses: 8
    Dernier message: 15/09/2005, 12h43
  5. Réponses: 2
    Dernier message: 10/07/2002, 11h51

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