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 :

Probléme avec la suppression de ligne dans un tableau


Sujet :

VBA Word

  1. #1
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 335
    Points : 112
    Points
    112
    Par défaut Probléme avec la suppression de ligne dans un tableau
    Bonjour,

    Avec ce que j'ai pu trouver sur le forum j'ai fait un petit code qui devrait me permettre de supprimer les lignes où les cellules sont vides.
    Voilà ce que ça donne :
    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
     
    Set tableau = ActiveDocument.Bookmarks("tableau1")
     
     
    Dim Numlignes As Variant
    Dim J As Integer
    Dim I As Integer
    Dim cellvide As Boolean
     
    I = 16
     
    Do Until I = 2
        cellvide = False
            For J = 2 To 5
                If ActiveDocument.Tables(1).Columns(J). _
                    Cells(I).Range.Text = Chr(13) & Chr(7) Then
                    cellvide = True
                End If
            Next J
            If cellvide = True Then
             tableau.Rows(I).Delete
             End If
    I = I - 1
     Loop
    Le problème est qu'à l'exécution j'ai une erreur "5992" m'indiquant qu'il ne peut pas accéder aux colonnes car les largeurs de colonnes ne sont pas les mêmes.

    Merci d'avance.

  2. #2
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 335
    Points : 112
    Points
    112
    Par défaut
    Si au lieu d'utiliser un bookmark, j'utilise le numéro du tableau ça marche. Peut-être que j'assigne mal le signet au tableau, comment fait-on ça dans les règles de l'art ?
    Ou peut-on nommer un tableau ?
    Merci d'avance pour vos réponses.

  3. #3
    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
    Essaie, de sélectionner tout le tableau, lorsque tu te trouve dans le tableau, tu as un petit symbole carré avec un flèche quatre directions.
    Si tu cliques sur ce symbole et que tu assigne le signet, ça devrait le faire.
    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 !

  4. #4
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 335
    Points : 112
    Points
    112
    Par défaut
    Malheureusement ça ne marche pas, il me dit : erreur 438, ce type d'objet ne permet pas d'effectuer cette propriété ou méthode. Et il me surligne l'endroit où il y a le mot collonnes.

  5. #5
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 335
    Points : 112
    Points
    112
    Par défaut
    Est-il possible de donner un nom à un tableau ?

  6. #6
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    335
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 335
    Points : 112
    Points
    112
    Par défaut
    Comme ça, ça marche :

    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
     
    Set r = Doc.Bookmarks("tableau1").Range
    Set t = r.Tables(0)
     
    Do Until I = 1
        cellvide = False
            For J = 2 To 5
                If t.Columns(J). _
                    Cells(I).Range.Text = Chr(13) & Chr(7) Then
                    cellvide = True
                End If
            Next J
            If cellvide = True Then
             t.Rows(I).delete
             End If
    I = I - 1
     Loop

  7. #7
    Membre à l'essai
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2005
    Messages : 6
    Points : 10
    Points
    10
    Par défaut Solution alternative
    Essayez de passer en mode de visualisation Normale. J'ai pu éviter ce message par ce chemin.

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

Discussions similaires

  1. [XL-2003] Petit Probléme avec VBA - Suppression d'info dans une listebox
    Par Antho35 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 26/10/2010, 11h46
  2. Problème avec le passage à la ligne dans une Textbox
    Par iFlo1 dans le forum Général Dotnet
    Réponses: 0
    Dernier message: 22/03/2009, 13h47
  3. problème avec les sauts de ligne dans une string
    Par hexdoc dans le forum Langage
    Réponses: 6
    Dernier message: 02/05/2008, 15h28
  4. problème avec la suppression des doublons dans arraylsit
    Par ulysse031 dans le forum Langage
    Réponses: 13
    Dernier message: 04/03/2007, 12h52

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