找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1607|回复: 7

[每日一码] 查找文字

[复制链接]
发表于 2013-11-30 19:08:52 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×

;;;查找文字
(defun c:g()
        (setq gst (getstring "输入截面:"))
        (setq co (getint "color:"))
        (setq ass (ssadd))
        (setq ss (ssget '((0 . "TEXT"))))
        (setq i 0)
        (while (setq ssn (ssname ss i))
                (setq ent (entget ssn))
                (setq st (cdr (assoc 1 ent)))
                (if (= st gst)
                                (progn
                                       
                                        (if (assoc 62 ent)
                                                (setq ent (subst (cons 62 co) (assoc 62 ent) ent))
                                                (setq ent (cons (cons 62 co) ent))
                                        )

                                        (entmod ent)
                                        (setq ass (ssadd ssn ass))
                                        (princ)
                                )
                                ()
                )
                (setq i (+ i 1))
        )
)

;;;查找文字(中间)
(defun c:gm()
        (setq gst (getstring "输入文字:"))
        (setq co (getint "color:"))
        (setq ass (ssadd))
        (setq ss (ssget '((0 . "TEXT"))))
        (setq i 0)
        (while (setq ssn (ssname ss i))
                (setq ent (entget ssn))
                (setq st (cdr (assoc 1 ent)))
                (if (t-in gst st)
                                (progn
                                       
                                        (if (assoc 62 ent)
                                                (setq ent (subst (cons 62 co) (assoc 62 ent) ent))
                                                (setq ent (cons (cons 62 co) ent))
                                        )

                                        (entmod ent)
                                        (setq ass (ssadd ssn ass))
                                        (princ)
                                )
                                ()
                )
                (setq i (+ i 1))
        )
)
;;;查找符合条件
(defun c:gc()
        (setq gst (getreal "输入数值:"))
        (setq co (getint "color:"))
        (setq ass (ssadd))
        (setq ss (ssget '((0 . "TEXT"))))
        (setq i 0)
        (while (setq ssn (ssname ss i))
                (setq ent (entget ssn))
                (setq st (cdr (assoc 1 ent)))
                (setq f (atof st))
                (if (or (= f 0.0) (< f gst))
                                ()
                                (progn
                                       
                                        (if (assoc 62 ent)
                                                (setq ent (subst (cons 62 co) (assoc 62 ent) ent))
                                                (setq ent (cons (cons 62 co) ent))
                                        )

                                        (entmod ent)
                                        (setq ass (ssadd ssn ass))
                                        (princ)
                                )
                )
                (setq i (+ i 1))
        )
)


(defun t-in(st1 st2 / st1-l st2-l i)
        (setq st1-l (strlen st1))
        (setq st2-l (strlen st2))
        (setq t-in-end nil)

        (if (>= st2-l st1-l)
                (progn
                        (setq i 0)
                        (while (and (<=  i (- st2-l st1-l)) (not t-in-end))
                                (setq i (+ i 1))
                                (if (= st1 (substr st2 i st1-l))
                                        (setq t-in-end T)
                                )
                       
                        )


                )
        )
        (setq t-in-end t-in-end)
)


(defun find-gl(no1 no2 / i stop tmp1 tmp2 tmp3)
        (setq i 0)
        (setq stop T)
        (while (and (setq tmp1 (nth i dwgall-list)) stop)
                (if (and (= (nth 0 tmp1) no1) (= (nth 1 tmp1) no2))
                        (progn
                                (setq tmp2 (nth 2 tmp1))
                                (setq tmp3 (strcat (rtos (nth 0 tmp2)) "*" (rtos (nth 1 tmp2)) "*" (rtos (nth 2 tmp2)) "*" (rtos (nth 3 tmp2)) "/" (rtos (nth 0 (nth 3 tmp1))) "/" (rtos (nth 0 (nth 4 tmp1)) 2 3)))
                                (if (setq tmp2 (nth 1 (nth 4 tmp1)))
                                        (setq tmp3 (strcat tmp3 "/" (rtos (nth 0 tmp2)) "*" (rtos (nth 1 tmp2)) "*" (rtos (nth 2 tmp2)) "*" (rtos (nth 3 tmp2)) "/" (rtos (nth 4 tmp2) 2 3)))
                                        ()
                                )
                                (setq stop nil)
                        )
                )
                (setq i (+ i 1))
        )
        (if stop
                (setq tmp3 nil)
                (setq tmp3 tmp3)
        )
)


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2013-11-30 21:07:28 | 显示全部楼层
楼主发帖的精神可嘉,但是有些代码已经过时了,还是发些与时俱进代码

点评

我这人说话不好听,有可能得罪很多人,但象楼主这样的,还是不发为好;要发也发一个压缩文件。  发表于 2013-12-1 01:48
但这符合学习的规律  详情 回复 发表于 2013-11-30 21:39
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2013-11-30 21:39:13 | 显示全部楼层
Free-Lancer 发表于 2013-11-30 21:07
楼主发帖的精神可嘉,但是有些代码已经过时了,还是发些与时俱进代码

但这符合大众学习的规律
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 34个

财富等级: 招财进宝

发表于 2013-12-13 14:43:37 | 显示全部楼层
都是高手,都值得学习
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2014-4-16 15:36:11 | 显示全部楼层
只是查找,没有替换~
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2018-1-18 11:25:53 | 显示全部楼层
谢谢分享谢谢分享谢谢分享谢谢分享谢谢分享谢谢分享谢谢分享谢谢分享谢谢分享
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-3-29 08:56 , Processed in 0.499280 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表