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 Word Discussion :

Tableau : sélectionner texte d'une cellule


Sujet :

VBA Word

  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 47
    Points : 34
    Points
    34
    Par défaut Tableau : sélectionner texte d'une cellule
    Bonjour

    J'ai un petit souci, que voici. Savez vous comment sélectionner le texte qui se trouve dans une cellule d'un tableau Word ? J'arrive à sélectionner la cellule, mais pas le texte.

    (Je ne peux pas utiliser de signet, hélas).

    Une idée ?

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Pour sélectionner le texte d'une cellule, il faut en plus de l'adressage de la cellule une petite fonction de nettoyage.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Public Function netText(stTemp As String)
        netText = Left( stTemp , (Len(stTemp) - 2 )
    End Function
    Pour obtenir le texte de la cellule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Document.Tables(1).Cell(1,1).Range.Text
    Avec l'application de la fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Dim myString As String
    myString = netText ( Document.Tables(1).Cell(1,1).Range.Text )
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Nouveau membre du Club
    Inscrit en
    Novembre 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 47
    Points : 34
    Points
    34
    Par défaut
    Mmmmh, j'ai essayé mais ça ne marche pas.

    Précisément, je cherche à intégrer un lien hypertexte dans une cellule d'un tableau, mais ça n'a l'air de marcher qu'avec des mots, et pas une cellule. (dans ce dernier cas, le lien apparait en clair, pas "derrière" le mot.

    Voila le code (avec un signet couvrant la cellule du tableau, pas avec la référence à une cellule d'un tableau) :

    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
    Sub exemple()
     
    LienHypertexte = "http://www.test.com/"
     
    Selection.GoTo What:=wdGoToBookmark, Name:="Societe"
     
    LienHypertexteSociete = Selection
     
     
    LienHypertexteAdresse = LienHypertexte & LienHypertexteSociete
     
    ActiveDocument.Hyperlinks.Add Anchor:=Selection.Range, Address:= _
            LienHypertexteAdresse
     
    End Sub
    J'ai essayé avec "Selection.range.text" à la fin, mais ça ne marche pas.

  4. #4
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Voilà le code que je viens d'essayer. J'ai simplement mis un signet sur le texte de la cellule, pas la cellule et j'ai bien le résultat que tu veux, maintenant, j'ai pas très bien compris ce que tu veux faire avec ton code.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Sub AjoutHyperlink()
    Dim stLink As String
    'Dim oTbl As Table
    stLink = "http://heureuxoli.developpez.com/"
     
    'Set oTbl = ActiveDocument.Tables(1)
    'oTbl.Cell(1, 1).Select
     
    Selection.Hyperlinks.Add Anchor:=ActiveDocument.Bookmarks("S1").Range, Address:=stLink
     
     
    End Sub
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 543
    Points
    15 543
    Par défaut
    J'ai essayé avec "Selection.range.text" à la fin, mais ça ne marche pas.
    Oui, parce qu'en fin de cellule, tu as un caractère indésirable. C'est bien pourquoi je te demandais ton code
    Pour avoir le lien tout propre, tu peux mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Lien = Left(ActiveDocument.Tables(1).Cell(1, 1).Range.Text, Len(ActiveDocument.Tables(1).Cell(1, 1).Range.Text) - 2)
    Avec Selection, tu remplaces ActiveDocument par selection
    Heureux... t'avait d'ailleurs mis la solution

  6. #6
    Nouveau membre du Club
    Inscrit en
    Novembre 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 47
    Points : 34
    Points
    34
    Par défaut
    Désolé, mais je n'ai pas été suffisamment clair.

    En fait, je travaille sur un fichier qui sera utilisés par plusieurs personnes. C'est un support de création pour la rédaction d'articles sur des sociétés. Le client, s'il lit l'article et veut en savoir plus sur la société, doit pouvoir cliquer sur le nom et arriver à la bonne partie du site web grâce à un lien hypertexte.

    L'adresse des sociétés sur le site web est toujours la même :

    www.nomdusiteweb.com/société


    Ce support de création est utilisé par plusieurs personnes. Elles doivent rentrer le nom de la société dans une case du tableau. Ensuite, la création du lien hypertexte doit être automatique.



    Le problème, c'est qu'il ne faut pas que le lien hypertexte soit visible ! Et ça...


    Encore désolé de ne pas avoir été clair.

  7. #7
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    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
    Sub AjoutHyperlink()
    Dim stLink As String
    Dim stSociete As String
     
     
     
    Dim oTbl As Table
    stLink = "http://heureuxoli.developpez.com/"
     
    Set oTbl = ActiveDocument.Tables(1)
    stSociete = netText(oTbl.Cell(1, 1).Range.Text)
     
    oTbl.Cell(1, 1).Select
    Selection.Delete
     
    Selection.Bookmarks.Add "S1"
     
    Selection.Hyperlinks.Add Anchor:=ActiveDocument.Bookmarks("S1").Range, Address:=stLink, TextToDisplay:=stSociete
     
    End Sub
    Et la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Public Function netText(stTemp As String)
        netText = Left(stTemp, (Len(stTemp) - 2))
    End Function
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  8. #8
    Nouveau membre du Club
    Inscrit en
    Novembre 2007
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 47
    Points : 34
    Points
    34
    Par défaut
    Ouf, merci. Désolé d'avoir été laborieux.

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

Discussions similaires

  1. [Débutant] Rajouter texte dans une cellule d'un tableau de cellules (cell array)
    Par DudeTitus dans le forum MATLAB
    Réponses: 2
    Dernier message: 20/06/2014, 13h12
  2. Position du texte dans une cellule d'un tableau
    Par kwazikwantik dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 4
    Dernier message: 12/12/2009, 18h25
  3. Réponses: 4
    Dernier message: 20/06/2008, 15h19
  4. [VBA] Problème récup texte d'une cellule dans un tableau
    Par Marco le Pouillot dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 30/01/2006, 17h06
  5. Faire défiler un texte dans une cellule de tableau
    Par Furius dans le forum Général JavaScript
    Réponses: 18
    Dernier message: 01/12/2005, 17h06

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