denis38 Posté(e) le 20 novembre 2009 Posté(e) le 20 novembre 2009 Bonsoir a tous, quelqu'un connaitrai t'il un moyen simple de convertir environ 300 ligne de texte en 300 ligne de texte multiligne sans passer par les menu express car il faut faire 300 fois la manip merci et bon weekend à tous denis
lecrabe Posté(e) le 20 novembre 2009 Posté(e) le 20 novembre 2009 Hello Si tu as les routines Express/Bonus installees, cette routine devrait te convenir ... :) Le Decapode ; T2M - convert individual Texts/Dtexts to individual MTexts ; modified by Xanadu - www.xanadu.cz ; ***** This routine NEEDS the Express Tools ***** (defun C:T2M (/ ss i elist) (prompt "\nSelect Text objects to convert to MTexts: ") (setq ss (ssget (list (cons 0 "TEXT")))) (setq i -1) (if ss (repeat (sslength ss) (setq elist (cdr (assoc -1 (entget (ssname ss (setq i (1+ i))))))) (command "TXT2MTXT" elist ""); Express Tools command ) ) ) Autodesk Expert Elite Team
denis38 Posté(e) le 20 novembre 2009 Auteur Posté(e) le 20 novembre 2009 Merci le decapote ça marche nikelJe te souhaite a toi et tous las autocadien un l'excellent weekend Denis
denis38 Posté(e) le 20 novembre 2009 Auteur Posté(e) le 20 novembre 2009 merci pour ta réponse si rapide Denis
didier Posté(e) le 22 novembre 2009 Posté(e) le 22 novembre 2009 coucou au moins ce forum a le mérite de nous faire nous poser des questions ..en l'occurrence je ne traite que TRES rarement les MText Toutefois, je ne vois pas l'utilité de cette routinepuisqu'on peut choisir par captureles textes (en lignes) à convertir en MTEXTvia la commande Express : TXT2MTXT amicalement Éternel débutant... Mon site perso : Programmer dans AutoCAD
lecrabe Posté(e) le 23 novembre 2009 Posté(e) le 23 novembre 2009 Hello Didier Non car la commande TXT2MTXT convertit les N TEXT selectionnes en UN SEUL MTEXT ! Ou alors j'ai rate qq chose d'enorme depuis 10 ans ! :o J'utilise tres souvent cette routine T2M pour obtenir N MTEXT bases sur N TEXT selectionnes pour en general mettre un masque d'arriere plan sur ces MTEXT ... Le Decapode Autodesk Expert Elite Team
fabcad Posté(e) le 23 novembre 2009 Posté(e) le 23 novembre 2009 Bonjour, Effectivement la fonction des express tools ne boucle pas sur les textes mais réalise une fusion des textes en un seul mtexte. J'utilise la fonctionnalité masque (largeur à 0 c'est plus facile à gérer) des mtextes comme Lecrabe et ce sans utiliser les formatages de textes a part un retour chariot pour mes mtextes de lieu-dit. A+ PS, La conversion sur MAP perd évidemment les données d'objets associées aux textes. Sinon voici ma routine améliorable en vlisp, elle gère les justifications :Le 30 novembre 2009 : Gestion de la justification gauche des textes ainsi que la gestion des données d'objets (enlever le point virgule devant : ;(copy_data c1 (entlast) nil) (defun c:fd-txts-to-mtxts (/ c1 i nbr js filtre ent pti-10 pti-11 pti-insertion just sty htr ang ang-deg chn lst-c1) (setvar "cmdecho" 0) (setq calq-org (getvar "clayer")) (setq filtre (list (cons 0 "TEXT"))) (setq js (ssget filtre)) (if js (progn (setq nbr (sslength js)) (setq i 0) (while (<= i (- nbr 1)) (setq c1 (ssname js i)) (setq ent (entget c1)) (setq lst-c1 (justif c1)) (setq just (cdr (assoc 1 lst-c1))) (setq pti-10 (cdr (assoc 10 (entget c1)))) (setq pti-11 (cdr (assoc 11 (entget c1)))) (if (and (= 0 (cdr (assoc 72 ent))) (= 0 (cdr (assoc 73 ent)))) (setq pti-insertion (cdr (assoc 10 (entget c1)))) (setq pti-insertion (cdr (assoc 11 (entget c1)))) );fin if (setq chn (cdr (assoc 1 (entget c1)))) (setq calq-ent (cdr (assoc 8 (entget c1)))) (setq ang (cdr (assoc 50 (entget c1)))) (setq ang-deg (* 180 (/ ang pi))) (setq sty (cdr (assoc 7 (entget c1)))) (setq htr (cdr (assoc 40 (entget c1)))) (command "-calque" "ch" calq-ent "") (command "-mtext" pti-insertion "Justifier" just "Style" sty "Hauteur" htr "Rotation" ang-deg "Largeur" "0" chn "") ;(copy_data c1 (entlast) nil) (entdel c1) (command "-calque" "choisir" calq-org "") (setq i (+ i 1)) );fin while nbr );fin progn (prompt "\nPAS D'OBJETS DE TYPE TEXTE SELECTIONNES !!!") );fin if (command "-calque" "choisir" calq-org "") (setvar "cmdecho" 1) (prompt "\n---COPYRIGHT 06/99 PAR Fabrice DEMIEL---") ) ;---------------------------------------------------------------------------- (prompt "\nPour lancer tapez : fd-txts-to-mtxts ") (prin1) ;---------------------------------------------------------------------------- (defun justif (nom / lst-nom typ-nom) (setq lst-nom (entget nom)) (setq typ-nom (cdr (assoc 0 lst-nom))) (cond ((= typ-nom "TEXT") (cond ((and (= 0 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Gauche !!!\n") (setq res-lst (list (cons 1 "BG") (cons 71 7) (cons 72 0) (cons 73 0))) );fin progn );fin ((and (= 1 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Centre !!!\n") (setq res-lst (list (cons 1 "BC") (cons 71 8) (cons 72 1) (cons 73 0))) );fin progn );fin ((and (= 2 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Droite !!!\n") (setq res-lst (list (cons 1 "BD") (cons 71 9) (cons 72 2) (cons 73 0))) );fin progn );fin ((and (= 3 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Aligné !!!\n") (setq res-lst (list (cons 1 "BG") (cons 71 7) (cons 72 3) (cons 73 0))) );fin progn );fin ((and (= 4 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Milieu !!!\n") (setq res-lst (list (cons 1 "MC") (cons 71 5) (cons 72 4) (cons 73 0))) );fin progn );fin ((and (= 5 (cdr (assoc 72 lst-nom))) (= 0 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Fixé !!!\n") (setq res-lst (list (cons 1 "BG") (cons 71 7) (cons 72 5) (cons 73 0))) );fin progn );fin ((and (= 0 (cdr (assoc 72 lst-nom))) (= 3 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Haut-Gauche !!!\n") (setq res-lst (list (cons 1 "HG") (cons 71 1) (cons 72 0) (cons 73 3))) );fin progn );fin ((and (= 1 (cdr (assoc 72 lst-nom))) (= 3 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Haut-Centre !!!\n") (setq res-lst (list (cons 1 "HC") (cons 71 2) (cons 72 1) (cons 73 3))) );fin progn );fin ((and (= 2 (cdr (assoc 72 lst-nom))) (= 3 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Haut-Droite !!!\n") (setq res-lst (list (cons 1 "HD") (cons 71 3) (cons 72 2) (cons 73 3))) );fin progn );fin ((and (= 0 (cdr (assoc 72 lst-nom))) (= 2 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Milieu-Gauche !!!\n") (setq res-lst (list (cons 1 "MG") (cons 71 4) (cons 72 0) (cons 73 2))) );fin progn );fin ((and (= 1 (cdr (assoc 72 lst-nom))) (= 2 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Milieu-Centre !!!\n") (setq res-lst (list (cons 1 "MC") (cons 71 5) (cons 72 1) (cons 73 2))) );fin progn );fin ((and (= 2 (cdr (assoc 72 lst-nom))) (= 2 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Milieu-Droite !!!\n") (setq res-lst (list (cons 1 "MD") (cons 71 6) (cons 72 2) (cons 73 2))) );fin progn );fin ((and (= 0 (cdr (assoc 72 lst-nom))) (= 1 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Bas-Gauche !!!\n") (setq res-lst (list (cons 1 "BG") (cons 71 7) (cons 72 0) (cons 73 1))) );fin progn );fin ((and (= 1 (cdr (assoc 72 lst-nom))) (= 1 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Bas-Centre !!!\n") (setq res-lst (list (cons 1 "BC") (cons 71 8) (cons 72 1) (cons 73 1))) );fin progn );fin ((and (= 2 (cdr (assoc 72 lst-nom))) (= 1 (cdr (assoc 73 lst-nom)))) (progn (prompt "\n Justification de type Bas-Droite !!!\n") (setq res-lst (list (cons 1 "BD") (cons 71 9) (cons 72 2) (cons 73 1))) );fin progn );fin );fin cond ); fin obj egal a TEXT );fin 1er cond res-lst );fin defun [Edité le 25/11/2009 par fabcad] [Edité le 30/11/2009 par fabcad]
Steven Posté(e) le 25 novembre 2009 Posté(e) le 25 novembre 2009 Salut fabcad. Je viens d'essayer ta routine sur un texte mais ce que je ne comprends pas, c'est que le texte se déplace pour aller se mettre sur le point 0,0 absolu de mon espace objet. Steven________________________________________ Pour le taf; Windows (et ses emmerdes) sinon pas d'AutoCAD. Pour le perso Linux Mint et pas de problèmes. Mais pas d'AutoCAD. En rêve; AutoCAD sous Linux.
lecrabe Posté(e) le 25 novembre 2009 Posté(e) le 25 novembre 2009 Hello Pour faite suite a la routine T2M.lspJe genere des masques d'arriere sur N objets MTEXTs avec cette routine ... Le Decapode ;; Written by: Lee Ambrosius ;; Created on: 4/7/2004 ;; http://www.hyperpics.com/ ;; This program allows you to add Background Mask to several Mtext objects ;; at one time instead of using the Mtext editor ;; for each object or the Properties Palette. ;; The Properties Palette in 2005 doesn't allow you ;; to set Background Color or Border Offset. (defun c:MTextMASK ( / kWordBackgroundMaskCurrent dOffsetCurrent ssMtext dxf90 dxf63 dxf45 dxf441) (prompt "\nApply Mtext Mask") (if (= kWordBackgroundMask nil) (setq kWordBackgroundMask "Background" kWordBackgroundMaskCurrent "Background") (setq kWordBackgroundMaskCurrent kWordBackgroundMask) ) (initget "None Background Color") (setq kWordBackgroundMask (getkword (strcat "\nSpecify Background Mask: [None/Background/Color] : "))) (if (= kWordBackgroundMask nil) (setq kWordBackgroundMask kWordBackgroundMaskCurrent) ) (cond ((= kWordBackgroundMask "Color") (if (or (= maskClr nil) (/= (type maskClr) 'LIST)) (setq maskClr (acad_truecolorcli 1)) (if (= (assoc 420 maskClr) nil) (setq maskClr (acad_truecolorcli (cdr (assoc 62 maskClr)))) (setq maskClr (acad_truecolorcli (assoc 420 maskClr))) ) ) ) ((= kWordBackgroundMask "Background")(setq maskClr 256)) ((= kWordBackgroundMask "None")(setq maskClr 0 dOffset 1.0)) ) (if (/= maskClr nil) (progn (if (/= kWordBackgroundMask "None") (progn (setq dOffsetCurrent dOffset) (if (= dOffsetCurrent nil) (setq dOffset 1.0 dOffsetCurrent 1.0) (setq dOffsetCurrent dOffset) ) (setq dOffset (getreal (strcat "\nSpecify border offset factor: : "))) (if (= dOffset nil) (setq dOffset dOffsetCurrent) ) (if (> dOffset 5)(setq dOffset nil)) (if ( (while (= dOffset nil) (setq dOffset (getreal (strcat "\nSpecify border offset factor: : "))) (if (> dOffset 5)(setq dOffset nil)) (if ( ) ) (if (= dOffset nil) (setq dOffset 1.0) ) ) (if (setq ssMtext (ssget (list (cons 0 "MTEXT")))) (progn (cond ((= kWordBackgroundMask "None") (setq mask_list (list (cons 90 2)(cons 63 0)(cons 45 dOffset)(cons 441 0)) dxf90 2 dxf63 nil dxf45 nil dxf441 nil ) ) ((and (= kWordBackgroundMask "Color")(/= (assoc 420 maskClr) nil)) (setq mask_list (list (cons 90 1)(cons 63 1)(cons 421 (cdr (assoc 420 maskClr)))(cons 45 dOffset)(cons 441 (cdr (assoc 420 maskClr)))) dxf90 1 dxf63 2 dxf45 dOffset dxf441 (cdr (assoc 420 maskClr)) ) ) ((and (= kWordBackgroundMask "Color")(= (assoc 420 maskClr) nil)) (setq mask_list (list (cons 90 1)(cons 63 (cdr (assoc 62 maskClr)))(cons 45 dOffset)(cons 441 2146608)) dxf90 1 dxf63 (cdr (assoc 62 maskClr)) dxf45 dOffset dxf441 nil ) ) ((= kWordBackgroundMask "Background") (setq mask_list (list (cons 90 3)(cons 63 3)(cons 45 dOffset)(cons 441 0)) dxf90 3 dxf63 256 dxf45 dOffset dxf441 0 ) ) ) (setq emax (sslength ssMtext) sscount 0 ) (while ( (setq EN (entget (ssname ssMtext sscount)) tempEN nil) (if (/= dxf90 nil) (progn (if (/= (assoc 90 EN) nil) (setq EN (subst (cons 90 dxf90) (assoc 90 EN) EN)) (setq EN (append EN (list (cons 90 dxf90)))) ) ) (progn (setq CNT 0 nMembers (member (assoc 90 EN) EN)) (if (= nMembers nil) (setq nMembers 0) (setq nMembers (length nMembers)) ) (repeat (- (length EN) nMembers) (setq tempEN (append tempEN (list (nth cnt EN)))) (setq CNT (1+ CNT)) ) (if (> nMembers 0) (progn (setq CNT 1) (repeat (- nMembers 1) (setq tempEN (append tempEN (list (nth cnt (member (assoc 90 EN) EN))))) (setq CNT (1+ CNT)) ) ) ) (setq EN tempEN tempEN nil) ) ) (if (/= dxf63 nil) (progn (if (/= (assoc 63 EN) nil) (setq EN (subst (cons 63 dxf63) (assoc 63 EN) EN)) (setq EN (append EN (list (cons 63 dxf63)))) ) ) (progn (setq CNT 0 nMembers (member (assoc 63 EN) EN)) (if (= nMembers nil) (setq nMembers 0) (setq nMembers (length nMembers)) ) (repeat (- (length EN) nMembers) (setq tempEN (append tempEN (list (nth cnt EN)))) (setq CNT (1+ CNT)) ) (if (> nMembers 0) (progn (setq CNT 1) (repeat (- nMembers 1) (setq tempEN (append tempEN (list (nth cnt (member (assoc 63 EN) EN))))) (setq CNT (1+ CNT)) ) ) ) (setq EN tempEN tempEN nil) ) ) (if (/= dxf45 nil) (progn (if (/= (assoc 45 EN) nil) (setq EN (subst (cons 45 dxf45) (assoc 45 EN) EN)) (setq EN (append EN (list (cons 45 dxf45)))) ) ) (progn (setq CNT 0 nMembers (member (assoc 45 EN) EN)) (if (= nMembers nil) (setq nMembers 0) (setq nMembers (length nMembers)) ) (repeat (- (length EN) nMembers) (setq tempEN (append tempEN (list (nth cnt EN)))) (setq CNT (1+ CNT)) ) (if (> nMembers 0) (progn (setq CNT 1) (repeat (- nMembers 1) (setq tempEN (append tempEN (list (nth cnt (member (assoc 45 EN) EN))))) (setq CNT (1+ CNT)) ) ) ) (setq EN tempEN tempEN nil) ) ) (if (/= dxf441 nil) (progn (if (/= (assoc 441 EN) nil) (setq EN (subst (cons 441 dxf441) (assoc 441 EN) EN)) (setq EN (append EN (list (cons 441 dxf441)))) ) ) (progn (setq CNT 0 nMembers (member (assoc 441 EN) EN)) (if (= nMembers nil) (setq nMembers 0) (setq nMembers (length nMembers)) ) (repeat (- (length EN) nMembers) (setq tempEN (append tempEN (list (nth cnt EN)))) (setq CNT (1+ CNT)) ) (if (> nMembers 0) (progn (setq CNT 1) (repeat (- nMembers 1) (setq tempEN (append tempEN (list (nth cnt (member (assoc 441 EN) EN))))) (setq CNT (1+ CNT)) ) ) ) (setq EN tempEN) ) ) (entmod EN) (setq sscount (1+ sscount)) ) ) ) ) ) (princ) ) (prompt "\nType MTEXTMASK to run the command") (princ) Autodesk Expert Elite Team
didier Posté(e) le 25 novembre 2009 Posté(e) le 25 novembre 2009 coucou je ne suis pas un habitué, c'est rien de le dire, des MTEXTaussi je n'avais pas compris l'intitulé originalje pensais qu'il voulait, justement, concaténer ses lignes de texte en un MTEXT parce que tout transformer en MTEXT :mad: :mad: il faut de bonnes raisons ... amicalement Éternel débutant... Mon site perso : Programmer dans AutoCAD
fabcad Posté(e) le 25 novembre 2009 Posté(e) le 25 novembre 2009 Hello, En effet les mtextes se déplacent je travaille dessus, ce sont les textes qui ont les justifications gauche centre droite car le point dxf 11 est à 0,0,0 alors qu'il faudrait que je prennes le point dxf 10. Le 30 nevembre 2009 : c'est réglé. A+ [Edité le 30/11/2009 par fabcad]
denis38 Posté(e) le 22 mars 2013 Auteur Posté(e) le 22 mars 2013 Bonjour a tous,me voila de retour sur le sujetle lisp "FD-TXTS-TO-MTXTS" marche bien mais!!!!pour les textes oblique ou une rotation différente de 90 cela ne fonctionne pas :( je cherche un expert pour modifier ou rajouter quelque ligne pour que ca marchele must si c'est réalisable, serait de le faire par lot, quelque soit la rotation du texte voila merci pour vos réponse CordialementDenis
Messages recommandés
Créer un compte ou se connecter pour commenter
Vous devez être membre afin de pouvoir déposer un commentaire
Créer un compte
Créez un compte sur notre communauté. C’est facile !
Créer un nouveau compteSe connecter
Vous avez déjà un compte ? Connectez-vous ici.
Connectez-vous maintenant