begin process at 2012 02 15 18:02:25
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Visual Basic 6

 > 

Langages dérivés

 > 

VBA

 > 

Macro vba pour créer des shape dans une cellule de tableau


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Macro vba pour créer des shape dans une cellule de tableau

mardi 17 février 2009 à 09:24:43 | Macro vba pour créer des shape dans une cellule de tableau

lolokun

Bonjour à tous,

Je réexplique mon souci, il s'agit en fait, lors de modification de procédure d'installation, de pouvoir rajouter dans la 1ère colonne d'un tableau à 2 colonnes, le numéro auto ainsi qu'un shape, permettant au technicien de cocher l'étape qu'il vient de réaliser.

Ce message fait suite à un post que j'avais déjà ouvert :
http://www.vbfrance.com/forum/sujet-MACRO-CREER-LISTE-NUMEROS-PUCES-DANS-TABLEAU_1268753.aspx


Voici donc où j'en suis maintenant :

Dim haut, Gauche, lignecourante As Integer
Dim shp As Shape

ActiveDocument.Tables(1).Rows.Add BeforeRow:=Selection.Rows(1)     'ajoute une ligne au dessus de la ligne sur laquelle se situe le curseur
lignecourante = Selection.Information(wdStartOfRangeRowNumber)         'récupérer le numéro de ligne active
'MsgBox Left(ActiveDocument.Tables(1).Cell(lignecourante, 2).Range.Text, Len(ActiveDocument.Tables(1).Cell(lignecourante, 2).Range.Text) - 2)  'test pour afficher le contenu de la 2nde colonne
lignecourante = lignecourante - 1      'récupère le numéro de la ligne nouvellement créée
'MsgBox Left(ActiveDocument.Tables(1).Cell(lignecourante, 2).Range.Text, Len(ActiveDocument.Tables(1).Cell(lignecourante, 2).Range.Text) - 2)
'MsgBox ActiveDocument.Tables(1).Cell(lignecourante, 1).Height
'MsgBox ActiveDocument.Tables(1).Cell(lignecourante, 1).Width
haut = CInt(ActiveDocument.Tables(1).Cell(lignecourante, 1).Height / 2)
Gauche = CInt(ActiveDocument.Tables(1).Cell(lignecourante, 1).Width / 2)

Set shp = ActiveDocument.Shapes.AddShape(msoShapeRectangle, Gauche, haut, 14, 7.5)


J'arrive donc à créer une ligne dans le tableau , à la sélectionner (d'ailleurs si quelqu'un aurait une autre méthode...Je n'ai pas réussi à utiliser moveup pour récupérer ensuite le numéro de la nouvelle ligne..)
Mon shape est bien créé, mais en haut de la feuille et non pas dans la 1ère cellule de ma ligne créée.

Il me semble que cela est dû au dernier paramètre [Anchor] pour spécifier que la position du shape doit se faire à partir  de la cellule et non du bord en haut à gauche de la feuille.

Comment faire pour que mon shape soit placé au bon endroit?
Merci par avance de votre attention.

L'expérience, c'est une connerie par jour, mais jamais la même..

mardi 17 février 2009 à 09:42:37 | Re : Macro vba pour créer des shape dans une cellule de tableau

lolokun

Réponse acceptée !
Bon hé bien j'ai fini par trouver la solution,comme je le supposais c'est ce paramètre là qu'il fallait modifier, et lui passer un objet de type range.
Cela fonctionne donc comme ceci :

Set shp = ActiveDocument.Shapes.AddShape(msoShapeRectangle, Gauche, haut, 14, 7.5, ActiveDocument.Tables(1).Cell(lignecourante, 1).Range)

Par contre, tant qu'à faire après avoir posté ce message, et étant novice en vba word, si quelqu'un a une proposition pour optimiser ce code, je suis preneur.

L'expérience, c'est une connerie par jour, mais jamais la même..


Cette discussion est classée dans : shape, tables, cell, activedocument, lignecourante


Répondre à ce message

Sujets en rapport avec ce message

pb de copier/coller feuille Excel-->tableau Word [ par crossrobotik ] salut a tou(te)s,je debute en VB (je fais plus de C++) et voila mon pb:j'ai une feuille Excel dans laquelle je veux extraire du texte en le copiant et En vbs, problème de modif de fichier Word [ par JMO ] Bonjour à tous....Suite à un précédent post, Renfield m'a bien dépanné pour:- avec un .vbs comment modifier un tableau dans un .doc;problème résolu.S VBA sous WORD 2003 [ par dchrist ] Bonjour tout le monde,J'ai un besoin d'aide assez urgent. J'ai un gros souci dans mon document WORD.J'explique le sujet.A partir d'un fichier texte, j Bordure et alignement dans un tableau lors d'un publipostage sur word à partir d'une application VB6 [ par cyrilou421 ] Bonjour,Dans mon application, j'effectue un publipostage sur word en vue d'imprimer ou d'enregistrer le document.Dans mon publipostage je dois mettre Piloter Word depuis Visual Studio 2010 VB [ par vbjpc ] Bonjour, Avec le code suivant, dans VBA Word 2010, je supprime l'entête et la recrée. Je voudrais pouvoir faire la même chose directement de visual Proportions de deux cercles [ par Cjvg ] Bonjour, J'ai un projet qui représente graphiquement la superficie de deux pays. J'utilise un composant shape (Cercle) de dimension [b]FIXE[/b] pour Comment Recuperer la CELL_ID de BTS sous android [ par marwenebhar ] slt MarDOS svp comment je peux récupérer la cell_id de bts pour utiliser sous android Mise à jour en cascade (Tables Mère/Fille) avec colonnes auto-incrementés [ par BasicZx81 ] Bonjour à tous, j'ai suivi l'excellent tuto de J.M Rabilloud sur Devellopez.com pourtant je me heurte à un problème : D'aprés le Tuto il est tout à fa Comportement bizzard : Les nouveaux enregistrements de la table Enfants sont ignorés [ par BasicZx81 ] Bonsoir, j'espère ne pas abuser en demandant une fois de plus de l'aide. J'ai un Dataset comprenant 2 tables Parents, Enfants. Si j'ajoute simultaném [Word 2007 - VBA] Extraire / supprimer le premier mot d'une page [ par PeaceMakah ] Bonjour tout le monde, Je suis débutant en VBA, merci de votre compréhension si je dis des énormités. Voici la situation : J'ai fait un publipostage


Nos sponsors


Sondage...

Comparez les prix

CalendriCode

Février 2012
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
272829    

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 3,682 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales