明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 405|回复: 4

[提问] 求帮忙修改一段论坛里的代码,修改成不分英文大小写

[复制链接]
发表于 2019-12-17 23:22 | 显示全部楼层 |阅读模式
3明经币
求帮忙修改一段论坛里的代码,修改成不分英文大小写


(defun c:cz ( / EN ENT GETPT I MAXP MINP PT S1 SS STXT)
(setvar "cmdecho" 0)
(command "undo" "be")
(setq stxt (getstring "\n输入查找的文字 :"))

(if (and (= stxt "")
          (setq s1 (entsel "\n选择要查找的文字 :"))
          (setq ent (entget(car s1)))
          (= (cdr(assoc 0 ent)) "TEXT,MTEXT"))
  (setq stxt (cdr(assoc 1 (entget(car s1)))))
)
(if (and  (setq ss (ssget (list '(0 . "TEXT,MTEXT") (cons 1 (strcat "*" stxt "*")))))
          (setq getpt(getpoint "\n指定线的起点:"))
         )
  (progn
  (setq i 0)
  (repeat (sslength ss)
   (setq en (ssname ss i))
   (vla-getboundingbox(vlax-ename->vla-object en) 'minp 'maxp)
   (setq minp (vlax-safearray->list minp)
         maxp (vlax-safearray->list maxp))
   (setq pt (polar minp (angle minp maxp) (/ (distance minp maxp) 2)))
   (entmake (list '(0 . "LINE") (cons 8 "FindText")(cons 10 getpt) (cons 11 pt)(cons 62 6) ))
   (setq i (1+ i))
  )
  (princ)
))
(command "undo" "end")
(setvar "CMDECHO" 1)
(princ)
)

最佳答案

查看完整内容

(defun c:cz ( / EN ENT GETPT I MAXP MINP PT S1 SS STXT) (setvar "cmdecho" 0) (command "undo" "be") (setq stxt (getstring "\n输入查找的文字 :")) (if (and (= stxt "") (setq s1 (entsel "\n选择要查找的文字 :")) (setq ent (entget(car s1))) (= (cdr(assoc 0 ent)) "TEXT,MTEXT") ) (setq stxt (cdr(assoc 1 (entget(car s1))))) ) (if (and (setq ss (ssget (list ...
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2019-12-17 23:22 | 显示全部楼层
(defun c:cz ( / EN ENT GETPT I MAXP MINP PT S1 SS STXT)
        (setvar "cmdecho" 0)
        (command "undo" "be")
        (setq stxt (getstring "\n输入查找的文字 :"))
        (if (and
                                (= stxt "")
                                (setq s1 (entsel "\n选择要查找的文字 :"))
                                (setq ent (entget(car s1)))
                                (= (cdr(assoc 0 ent)) "TEXT,MTEXT")
                        )
                (setq stxt (cdr(assoc 1 (entget(car s1)))))
        )
        (if (and
                                (setq ss (ssget (list
                                                                                                        '(0 . "TEXT,MTEXT")
                                                                                                        '(-4 . "<or")
                                                                                                        (cons 1 (strcat "*" (strcase stxt) "*"))
                                                                                                        (cons 1 (strcat "*" (strcase stxt t) "*"))
                                                                                                        '(-4 . "or>")
                                                                                                )
                                                                 )
                                )
                                (setq getpt(getpoint "\n指定线的起点:"))
                        )
                (progn
                        (setq i 0)
                        (repeat (sslength ss)
                                (setq en (ssname ss i))
                                (vla-getboundingbox (vlax-ename->vla-object en) 'minp 'maxp)
                                (setq
                                        minp (vlax-safearray->list minp)
                                        maxp (vlax-safearray->list maxp)
                                )
                                (setq pt (polar minp (angle minp maxp) (/ (distance minp maxp) 2)))
                                (entmake (list
                                                                         '(0 . "LINE")
                                                                         (cons 8 "FindText")
                                                                         (cons 10 getpt)
                                                                         (cons 11 pt)
                                                                         (cons 62 6)
                                                                 )
                                )
                                (setq i (1+ i))
                        )
                        (princ)
                )
        )
        (command "undo" "end")
        (setvar "CMDECHO" 1)
        (princ)
)
回复

使用道具 举报

发表于 2019-12-17 23:31 | 显示全部楼层
  • (defun c:cz ( / en ent getpt i maxp minp pt s1 ss stxt)
  • (setvar "cmdecho" 0)
  • (command "undo" "be")
  • (setq stxt (getstring "\n输入查找的文字 :"))
  • (if (and (= stxt "")
  •            (setq s1 (entsel "\n选择要查找的文字 :"))
  •            (setq ent (entget(car s1)))
  •            (= (cdr(assoc 0 ent)) "text,mtext"))
  •    (setq stxt (cdr(assoc 1 (entget(car s1)))))
  • )
  • (if (and  (setq ss (ssget (list '(0 . "text,mtext") (cons 1 (strcat "*" stxt "*")))))
  •            (setq getpt(getpoint "\n指定线的起点:"))
  •           )
  •    (progn
  •    (setq i 0)
  •    (repeat (sslength ss)
  •     (setq en (ssname ss i))
  •     (vla-getboundingbox(vlax-ename->vla-object en) 'minp 'maxp)
  •     (setq minp (vlax-safearray->list minp)
  •           maxp (vlax-safearray->list maxp))
  •     (setq pt (polar minp (angle minp maxp) (/ (distance minp maxp) 2)))
  •     (entmake (list '(0 . "line") (cons 8 "findtext")(cons 10 getpt) (cons 11 pt)(cons 62 6) ))
  •     (setq i (1+ i))
  •    )
  •    (princ)
  • ))
  • (command "undo" "end")
  • (setvar "cmdecho" 1)
  • (princ)
  • )
回复

使用道具 举报

发表于 2019-12-17 23:33 | 显示全部楼层
请下载这个工具,


本帖子中包含更多资源

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

x
回复

使用道具 举报

 楼主| 发表于 2019-12-18 15:53 | 显示全部楼层
taoyi0727 发表于 2019-12-17 23:34
(defun c:cz ( / EN ENT GETPT I MAXP MINP PT S1 SS STXT)
        (setvar "cmdecho" 0)
        (command "undo" "be ...

感激~~~~~~~~~~~~~~~~~~~
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-5-17 09:43 , Processed in 0.158659 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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