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 :

Comment selectionner une ligne complète d'un .doc


Sujet :

VBA Word

  1. #1
    Membre du Club
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mai 2013
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2013
    Messages : 75
    Points : 57
    Points
    57
    Par défaut Comment selectionner une ligne complète d'un .doc
    Bonjour,

    Je débute en VBA et je cherche à faire une petite macro :
    Je souhaite ouvrir un fichier .doc, sélectionner la ligne 13 par exemple, et la remplacer par "coucou" par exemple.

    Voici mon code actuel :
    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
    Sub EcriDansWord()
     Dim WordObj As Object
     On Error Resume Next
     Set WordObj = CreateObject("Word.Application.8")
     Set wrdDoc = WordObj.Documents.Open("C:\Desktop\Source\Page_dossier_etude.doc")
     'Pour afficher Word
     WordObj.Visible = True
     
    With WordObj.Selection
    ---> Ici !
    J'aimerais selctionner la ligne 13 déja remplie, puis la remplacer par "coucou" par exemple
     End With
     
    'pour imprimer le document
     WordObj.PrintOut
     Set WordObj = Nothing
     End Sub
    Avez-vous une solution ? SVP

    Je vous remercie !

    Thomas.

  2. #2
    Membre du Club
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mai 2013
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2013
    Messages : 75
    Points : 57
    Points
    57
    Par défaut
    J'ai trouvé que ça pour le moment :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        Selection.MoveDown Unit:=wdLine, Count:=16
        Selection.MoveLeft Unit:=wdWord, Count:=1
        Selection.EndKey Unit:=wdLine, Extend:=wdExtend
        Selection.TypeText Text:="Coucou"

  3. #3
    Rédacteur/Modérateur

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

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

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

    On peut utiliser le range de la ligne, mais ta définition de ligne est un peu vague.
    En général, on utilise des paragraphes qui sont des objets Word.

    Active
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Document.paragraphs(13).range.text = "Coucou"

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Septembre 2013
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 38
    Points : 48
    Points
    48
    Par défaut
    Bonjour,

    on peut essayer ceci
    une méthode pour remplacer tout un paragraphe
    une autre pour remplacer une ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     Selection.HomeKey Unit:=wdStory 'se positionner au début du document
    'sélectionner un paragraphe et insérer un mot à la place
    ActiveDocument.Paragraphs(2).Range.Select 'facultatif
    ActiveDocument.Paragraphs(2).Range.Text = "Coucou "
    Selection.MoveDown Unit:=wdLine, Count:=10 'sélectionner la ligne 10
    Selection.EndKey Unit:=wdLine, Extend:=wdExtend 'sélectionner jusqu'à la fin de la ligne
    Selection.TypeText Text:="Coucou " 'taper le mot

  5. #5
    Membre du Club
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mai 2013
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2013
    Messages : 75
    Points : 57
    Points
    57
    Par défaut
    Merci !!! C'est parfait, cela fonctionne ! Mais j'ai un nouveau problème, je suis sûr que c'est un petit truc mais je ne comprends pas :

    Je cherche à mettre une combobox sur une fenetre mais, la liste ne s'affiche pas quand je clique dessus... Il faut que je fasse un espace par exemple pour que la liste s'affiche, je ne comprends pas pourquoi :
    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub ComboBox1_Change()
     
    ComboBox1.ColumnCount = 1
    ComboBox1.List() = Array("", "Villa", "Appartement", "Maison")
     
    End Sub
    Je ne comprends pas...
    Avez-vous une solution ? svp

    Merci d'avance chers développeurs

    Thomas

  6. #6
    Rédacteur/Modérateur

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

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

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

    Ta liste n'est peuplée que lorsque l'évènement Change est détecté.
    En général, on ne peuple pas une liste sur un évènement de cette liste, on peuple la liste lors du chargement du formulaire.

  7. #7
    Membre du Club
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mai 2013
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2013
    Messages : 75
    Points : 57
    Points
    57
    Par défaut
    Oui c'est ce que je cherche à faire :
    Lorsque je clique sur le pop-up, j'aimerais voir ma liste...
    Comment faire ? :/ SVP

  8. #8
    Membre du Club
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mai 2013
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Mai 2013
    Messages : 75
    Points : 57
    Points
    57
    Par défaut
    C'est bon ! Je viens de comprendre ! Merci !

    Désolé j'avais pas compris sur le coup !

    Merci bien !

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 13/05/2009, 16h26
  2. Comment tester si on a selectionné une ligne ou une colonne
    Par damoiselle dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 07/12/2007, 13h07
  3. Réponses: 1
    Dernier message: 18/11/2006, 15h06
  4. Réponses: 5
    Dernier message: 19/10/2006, 15h05
  5. Réponses: 2
    Dernier message: 08/08/2006, 09h41

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