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

VBA Discussion :

CheckSpelling: filtrer sur plusieurs langues


Sujet :

VBA

  1. #1
    Membre régulier
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juin 2011
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 248
    Points : 74
    Points
    74
    Par défaut CheckSpelling: filtrer sur plusieurs langues
    Bonjour à tous,

    Tout est dans le titre, je n'arrive pas à filtrer sur plusieurs langues, je souhaite faire un truc du genre:

    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
    22
    23
     
    Private Function RemoveDicoWords(myText() As String) As String()
     
        Dim newText() As String
        Dim j As Integer
        j = 0
        Dim n As Integer
        n = UBound(mytext)
        ReDim newText(n)
     
     
     
        For i = 0 To n
            If Not Application.CheckSpelling(myText(i), Languages(wdEnglishUS)) And Not Application.CheckSpelling(myText(i), Languages(wdFrench)) Then
                newText(j) = myText(i)
                j = j + 1
            End If
     
        Next
     
     
        RemoveDicoWords = newText
    End Function

    Mais la syntaxe du Checkspelling ne vas pas
    "Les ordinateurs font toujours ce qu'on leur dit, mais jamais ce qu'on veut."

  2. #2
    Membre régulier
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juin 2011
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 248
    Points : 74
    Points
    74
    Par défaut
    J'ai pu faire ça, pour un filtrage en englais:

    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
    22
    23
    24
    25
    26
    27
    28
    29
     
     
    Private Function RemoveDicoWords(myText() As String) As String()
     
        Dim newText() As String
        Dim j As Integer
        j = 0
        Dim n As Integer
        n = UBound(mytext)
        ReDim newText(n)
     
        With Application.SpellingOptions
            .DictLang = 1033 ' United States English language number.
            .UserDict = "CUSTOM.DIC"
        End With
     
     
     
        For i = 0 To n
            If Not Application.CheckSpelling(myText(i)) Then
                newText(j) = myText(i)
                j = j + 1
            End If
     
        Next
     
     
        RemoveDicoWords = newText
    End Function
    Ca marche bien, mais je souhaiterais tout filtrer d'un coup en une passe !! Sans devoir déclarer la langue avant...
    "Les ordinateurs font toujours ce qu'on leur dit, mais jamais ce qu'on veut."

  3. #3
    Membre régulier
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juin 2011
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 248
    Points : 74
    Points
    74
    Par défaut
    Mais de façon générale je ne suis pas sûr de savoir sélectionner le bon dictionnaire.... car je pense filtrer en français, mais des mots comme "that", "are" sont pris en compte....
    "Les ordinateurs font toujours ce qu'on leur dit, mais jamais ce qu'on veut."

  4. #4
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Bonjour

    Précise s'il te plait :
    1) ce que contient exactement la matrice myText et comment elle a été abondée
    2) ce que tu souhaites que contienne exactement la matrice RemoveDicoWords (ta fonction)

    L'analyse "en diagonale" de ton code (le premier) laisse penser que tu souhaites n'abonder la matrice résultat que par des articles non acceptés tant par une langue que par l'autre
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  5. #5
    Membre extrêmement actif
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Points : 12 422
    Points
    12 422
    Par défaut
    Il semble par ailleurs que tu développe sous VBA/Word, que je ne connais pas.
    Il serait sans doute plus astucieux de poser ta question dans le forum VBA/Word, plutôt que dans la section VBA/général

    J'ai malgré tout fait un petit tour dans laide interne de ton outil de développement (VBA/Word)
    Je n'en suis poas certain, mais je crois comprendre qu'il te faut, dans ton cas, pointer vers un dictionnaire
    - rubrique Dictionary.LanguageID, propriété de ton aide interne VBA
    Lire également la rubrique Dictionary.LanguageSpecific, propriété
    Une autre fois : je ne connais pas Word, mais ces lectures me laissent penser que l'on ne peut travailler sur deux dictionnaires à la fois
    Il est par contre toujours possible de procéder en deux temps :
    1) vérification dans un dictionnaire -->>
    ---- si vrai ---> OK -->> sortie sur OK
    ----- si non OK ---->> 2) vérification dans l'autre dictionnaire --->>
    ---- si vrai --->> OK
    ---- si non ---> REJET
    Je n'accepte pas de demande d' "amitié" individuelle. Tout développeur est pour moi un ami.
    Je n'ouvre AUCUN classeur tiers (avec ou sans macro ******). Ne m'en proposez donc pas .

    ****** : Non, non ... un classeur .xlsx ne "peut" par exemple et entre autres pas contenir un activex (de surcroît invisible) , "bien sûr" ...

    Il est illusoire de penser que l'on saurait exprimer valablement et précisément en un langage (rigide) de développement ce que l'on peine à exprimer dans le langage naturel, bien plus souple.

  6. #6
    Inactif  

    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2012
    Messages
    4 904
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2012
    Messages : 4 904
    Points : 10 168
    Points
    10 168
    Billets dans le blog
    36
    Par défaut
    Citation Envoyé par wilfryjules Voir le message
    Mais de façon générale je ne suis pas sûr de savoir sélectionner le bon dictionnaire.... car je pense filtrer en français, mais des mots comme "that", "are" sont pris en compte....
    Mais are, c'est aussi un mot français.

    D'un autre côté, Word est supposé choisir automatiquement le dictionnaire en fonction de la langue indiquée dans les options, ou la langue détectée dans le document. Je doute que l'on puisse tester deux langues en même temps. En principe, si le mot n'est pas dans le dictionnaire principal, alors Word regarde dans le dictionnaire personnel.
    À ma connaissance, le seul personnage qui a été diagnostiqué comme étant allergique au mot effort. c'est Gaston Lagaffe.

    Ô Saint Excel, Grand Dieu de l'Inutile.

    Excel n'a jamais été, n'est pas et ne sera jamais un SGBD, c'est pour cela que Excel s'appelle Excel et ne s'appelle pas Access junior.

  7. #7
    Membre régulier
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Juin 2011
    Messages
    248
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2011
    Messages : 248
    Points : 74
    Points
    74
    Par défaut
    Merci, au final j'ai fait 2 fonctions:
    - une qui retire les mots français
    - une qui retire les mots anglais
    "Les ordinateurs font toujours ce qu'on leur dit, mais jamais ce qu'on veut."

Discussions similaires

  1. Filtrer sur plusieurs feuilles avec VBA
    Par Tikalins dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 09/07/2015, 09h48
  2. [AC-2007] Filtrer sur plusieurs tables
    Par nanda5810 dans le forum IHM
    Réponses: 1
    Dernier message: 06/01/2014, 08h40
  3. Réponses: 7
    Dernier message: 04/01/2011, 10h47
  4. [XL-2007] Filtrer sur plusieurs feuilles
    Par fisio dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 12/09/2010, 23h05
  5. contrib.admin : filtrer sur la langue
    Par kazhar dans le forum Django
    Réponses: 1
    Dernier message: 18/05/2009, 17h57

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