保存指定文字对象的文字内容及文字所在位置块的图层名称和块名称到文本
保存指定文字对象的文字内容及文字所在位置块的图层名称和块名称到文本保存的txt数据格式:
文字内容,文字处块所在图层名称,文字处块名称
1,A,ZH1
18,A,ZH2
168,A,ZH3
8-1,D-2,ZH3
8-18,D-2,ZH1
8-168,D-2,ZH2
DSY1,8,ZH1
DSY18,8,ZH2
DSY168,8,ZH3
有劳论坛大神百忙中抽空弄个lsp用用!谢谢!谢谢!!
本帖最后由 ssyfeng 于 2018-11-5 22:41 编辑
修改了保存与当前dwg同名同目录的txt文件:
本帖最后由 ssyfeng 于 2018-11-5 16:28 编辑
试试这个行不行:(defun c:tt (/ *error* blc-en blc-name blc-name0 cr-pt dis0 dis1 en en-pt lay lay0 lst lst0 pt1 pt2 ss1 ss1-n ss2 ss2-n str txt-file)
(defun *error* ( msg )
(if (not (wcmatch (strcase msg t) "*break,*cancel*,*exit*"))
(progn (princ (strcat "\n错误:" msg)) (close txt-file))
)
(princ)
)
(setq pt1 (getpoint "\n选择对象范围:")
pt2 (getcorner pt1 "\n选择对象范围:")
ss1 (ssget "_c" pt1 pt2 '((0 . "text") (8 . "编号")))
ss2 (ssget "_c" pt1 pt2 '((0 . "INSERT")))
ss1-n (sslength ss1)
ss2-n (sslength ss2)
txt-file (open "c:\\str-lay-name.txt" "w")
)
(repeat ss1-n
(setq en (ssname ss1 (setq ss1-n (1- ss1-n)))
str (cdr (assoc 1 (entget en)))
en-pt (cdr (assoc 10 (entget en)))
dis0 99999999
)
(repeat ss2-n
(setq blc-en (ssname ss2 (setq ss2-n (1- ss2-n)))
cr-pt (cdr (assoc 10 (entget blc-en)))
blc-name (cdr (assoc 2 (entget blc-en)))
lay (cdr (assoc 8 (entget blc-en)))
dis1 (distance en-pt cr-pt)
)
(if (< dis1 dis0)
(progn (setq dis0 dis1
blc-name0 blc-name
lay0 lay
)
)
)
)
(setq lst0 (append lst0 (list (list str lay0 blc-name0)))
ss2-n (sslength ss2)
)
)
(setq lst (mapcar '(lambda (x) (strcat (car x) "," (cadr x) "," (caddr x))) lst0))
(mapcar '(lambda (x) (write-line x txt-file)) lst)
(close txt-file)
(princ)
)
ssyfeng 发表于 2018-11-5 15:12
试试这个行不行:
有劳大神看看,这是什么情况?谢谢!谢谢!! 本帖最后由 ssyfeng 于 2018-11-5 17:11 编辑
你重新下载最新的试试
ssyfeng 发表于 2018-11-5 17:05
你重新下载最新的试试
是用的 2018-11-5 16:28 编辑的代码,不知道是不是我CAD版本的问题,我用的是cad2016
还有想请教下,当块数量多一点的时候,比如800多个就有会停止响应一回儿,如图:
最后运行的结果还是没像您演示动画里生成了txt文件,只在命令历史记录里有显示:
有劳大神给看看是什么情况,再次表示衷心的感谢,谢谢!!
你用的应该还是旧的,我打包上传吧,你重新打开CAD,再加载试试
ssyfeng 发表于 2018-11-5 17:28
你用的应该还是旧的,我打包上传吧,你重新打开CAD,再加载试试
我对比了下您上传的lisp和2楼的代码是一致的,
运行结果也如上所叙,有劳您再给看看,谢谢!
下班了,迟一点再看看 上传你测试的文件看看
页:
[1]
2