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 :

Code Extraction de mots à partir de cellules to colonnes


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2011
    Messages
    108
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2011
    Messages : 108
    Par défaut Code Extraction de mots à partir de cellules to colonnes
    Bonjour tous

    Une chaîne de texte dans une cellule constituée de deux langues
    Extrait mots arabes dans une colonne
    Et l'anglais dans la dernière colonne
    exemple :
    احمد محمد اسف نجدي Ahmad mohmmad asf nagde
    colonne1 = احمد محمد اسف نجدي
    colonne 2 = Ahmad mohmmad asf nagde

    Car il ya plus conscients des différentes cellules des mots

  2. #2
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bonjour,

    J'ai fait un test avec une seule cellule en A1
    Je te laisse le soin de te faire une boucle si nécessaire...

    Le principe que j'ai utilisé, c'est de mettre tous les mots dans un tableau et ensuite vérifier chaque élément pour les reconstruire. Dans mon système, les caractères des mots arabes ont 63 (?) comme code ASCII, alors je me sers de ça pour déterminer les mots français et ceux arabes et les reconstruire...

    Si ça ne fonctionne pas de la même manière sur ton PC, alors, mon code ne te servira pas...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    Sub Extraire()
        Dim I As Long
        Dim Tablo() As String
        Dim strFR As String, strAR As String
     
        Tablo = Split(Range("A1"), " ")
        For I = 0 To UBound(Tablo)
            If Tablo(I) <> "" Then
                If Asc(Mid(Tablo(I), 1, 1)) <> 63 Then
                    strFR = strFR & Tablo(I) & " "
                Else
                    strAR = strAR & Tablo(I) & " "
                End If
            End If
        Next
     
        Range("B1") = Left(strFR, Len(strFR) - 1)
        Range("C1") = Left(strAR, Len(strFR) - 1)
    End Sub

  3. #3
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut
    Bonjour,

    sur ma version après coller, l'anglais et l'arabe s'inverse dans la cellule …

    Sinon parmi utilise AscW, c'est plus facile pour directement effectuer la séparation …

  4. #4
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 609
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 609
    Par défaut
    Bien vu Marc-L
    Je n'aurais pas pensé à ça...
    Faut dire que je n'ai jamais eu à travailler avec de l'arabe...

    Donc, on pourrait dire, j'imagine
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If AscW(Mid(Tablo(I), 1, 1)) <= 255 then  'non arabe
    plutôt que Asc(...) <> 63

  5. #5
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut

    Heu … Tu n'as pas besoin de Mid puisque la fonction Asc et dérivées renvoient le code du premier caractère d'une chaîne …

    Ou > 255 pour de l'arabe, voir même beaucoup plus haut comme 1000 par exemple.
    Le demandeur devrait connaitre à partir de quel n° de code ASCII étendu commence l'alphabet arabe …

  6. #6
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut
    Bon en fait pour l'inversion c'est normal à l'écran mais en interne l'ordre est bien respecté …

    Donc voici une proposition sans utiliser volontairement Split :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    Sub Demo()
        TXT$ = Application.Trim([A1].Value)
     
        Do
            W% = AscW(Mid$(TXT, P& + 1))
     
            If W And W < 1500 Then
                If P > 1 Then
                    [B1].Value = Left$(TXT, P - 1)
                    [C1].Value = Mid$(TXT, P + 1)
                Else
                    [C1].Value = TXT
                End If
     
                Exit Do
            End If
     
            P = InStr(P + 1, TXT, " ")
            If P = 0 Then [B1].Value = TXT
        Loop Until P = 0
    End Sub

    __________________________________________________________________________________________

    Merci de cliquer sur pour chaque message ayant aidé puis sur pour clore cette discussion …

    __________________________________________________________________________________________
    Un scientifique lira des centaines de livres au cours de sa vie, mais sera toujours persuadé qu'il lui reste beaucoup à apprendre.
    Un religieux n'en lira qu'un et sera persuadé d'avoir tout compris …


Discussions similaires

  1. Extraction de mots clés
    Par Olive1808 dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 01/02/2016, 20h49
  2. [XL-2007] extraction 1er/dernier mot d'une cellule
    Par cedinfo17 dans le forum Excel
    Réponses: 4
    Dernier message: 28/08/2011, 04h07
  3. extraction des mots à partir dune chaine de caractères
    Par khaledklaud dans le forum Langage
    Réponses: 2
    Dernier message: 30/09/2008, 16h13
  4. Affichage d'un mot à partir du code ascii
    Par husobom dans le forum Prolog
    Réponses: 1
    Dernier message: 30/12/2007, 23h22
  5. [PHP-JS] Extraction de données à partir d'un select
    Par Le Rebel dans le forum Langage
    Réponses: 3
    Dernier message: 30/01/2006, 10h11

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