转换单个字符i
将pdf转换为dxf后,所有转换的文本显示为单个字符(如图所示)。有没有办法使用lisp将其转换回单词和句子?可以这样做,只需制作一个字符及其x插入位置的“列表”x的原因是它们可能没有按照查看的顺序创建,因此您的列表必须反映查看时的连续字符串,然后您可以使用字符之间的距离因子来暗示一个空格,因为空格不存在。倾斜文本??
快速思考文本非perp使用左下边界框点,而不是插入pt来计算顺序。 试试这个马瑞克。
(defun c:GatherTexts (/ ss i sn e lst l st)
;;;;; Tharwat 01. Nov. 2012 ;;;;;
;;;;; gathering TEXT entities all together in ;;;;;
;;;;; the first left entity from the selection set ;;;;;
(or acdoc (setq acdoc (vla-get-activedocument (vlax-get-acad-object))))
(if (setq ss (ssget "_:L" '((0 . "TEXT"))))
(progn (repeat (setq i (sslength ss))
(setq sn (ssname ss (setq i (1- i))))
(setq e (entget sn))
(setq lst (cons (list (cdr (assoc 10 e)) (cdr (assoc 1 e)) sn) lst))
)
(setq l (vl-sort lst '(lambda (a b) (< (car (car a)) (car (car b))))))
(setq st (apply 'strcat (mapcar 'cadr l)))
(vla-StartUndoMark acdoc)
(if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (car l)))) (entget (caddr (car l)))))
(progn (setq l (reverse l)) (setq l (vl-remove (last l) l)) (mapcar 'entdel (mapcar 'caddr l)))
)
(vla-EndUndomark acdoc)
)
(princ)
)
(princ)
)
如果你是Tharwat,它工作得很好,但只适用于水平和倾斜文本。如果文字是垂直的:则将其反转。我不知道这是选择方式的问题(我想我尝试了所有方法)还是需要为代码做些什么。
如果您愿意,可以使用一个示例dwg进行测试。
测验图纸 很抱歉造成混淆,这是因为我只编写了水平文本的代码,所以现在试试。
(defun c:Test (/ ss i sn e lst l st p r)
;;;;; Tharwat 01. Nov. 2012 ;;;;;
;;;;; gathering TEXT entities all together in ;;;;;
;;;;; the first left entity from the selection set ;;;;;
(or acdoc (setq acdoc (vla-get-activedocument (vlax-get-acad-object))))
(if (setq ss (ssget "_:L" '((0 . "TEXT"))))
(progn (repeat (setq i (sslength ss))
(setq sn (ssname ss (setq i (1- i))))
(setq e (entget sn))
(setq lst (cons (list (cdr (assoc 10 e)) (cdr (assoc 1 e)) sn) lst))
)
(setq l (vl-sort lst '(lambda (a b) (< (car (car a)) (car (car b))))))
(setq st (apply 'strcat (mapcar 'cadr l)))
(setq p (mapcar 'car (mapcar 'car lst)))
(foreach x p
(if (equal x (car p))
(setq r (cons x r))
)
)
(vla-StartUndoMark acdoc)
(if (eq (length r) (length p))
(progn (setq st (vl-list->string (reverse (vl-string->list st))))
(if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (last l)))) (entget (caddr (last l)))))
(progn (setq l (reverse l)) (setq l (vl-remove (car l) l)) (mapcar 'entdel (mapcar 'caddr l)))
)
)
(if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (car l)))) (entget (caddr (car l)))))
(progn (setq l (reverse l)) (setq l (vl-remove (last l) l)) (mapcar 'entdel (mapcar 'caddr l)))
)
)
(vla-EndUndomark acdoc)
)
(princ)
)
(princ)
)
塔瓦,你是个完美的人。
我想为没有提及各种文本旋转而道歉。
干得好,非常感谢。我真的很感激。
听到这个消息我很高兴。
非常欢迎你,马瑞克。 这是我的版本:
上述应正确处理在任何旋转时对齐的字符。
使用文件中的示例:
另一个很棒的。谢谢你,李。现在我可以一次选中所有项目,一次完成。完美的非常感谢你。
谢谢你,马瑞克,不客气。
页:
[1]