找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 764|回复: 2

[求助] [求助]:这段子程序看不太懂谁能给个注释谢谢。(chktxt)

[复制链接]
发表于 2005-4-2 14:27:36 | 显示全部楼层 |阅读模式

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

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

×
(defun c:lsp_36()
(prompt "\n选取文字...")
(setq ss (ssget))
(setq i 0)
(repeat (sslength ss)
(setq ssn (ssname ss i))
(setq ssdata (entget ssn))
(setq sstyp (cdr (assoc 0 ssdata)))
(if (= sstyp "TEXT")
(progn
(setq old_txt (assoc 1 ssdata))
(setq txt (cdr old_txt))
(chktxt)
(setq new_txt (cons 1 pp))
(setq ssdata (subst new_txt old_txt ssdata))
(entmod ssdata)
)
)
(setq i (1+ i))
)
)
(defun chktxt() ;判断文字,转换大小写子程序
(setq p "" pp "" n 1 key nil)
(repeat (strlen txt)
(setq pk p)
(setq p (substr txt n 1))
(if (= n 1)
(setq key t)
(if (= pk " ") (setq key t) (setq key nil))
)
(if (= key nil)
(setq pp (strcat pp (strcase p t)))
(setq pp (strcat pp (strcase p)))
)
(setq n (1+ n))
)
)
(princ "\n---------->> LSP_36 <<----------")
(prin1)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-4-2 14:59:15 | 显示全部楼层
(defun c:lsp_36()
(prompt "\n选取文字...")
(setq ss (ssget));;;;选取需要大小写转换的文字
(setq i 0);;;;;记数器归0
(repeat (sslength ss);;;;;进入循环次数为你选择对象的数量
(setq ssn (ssname ss i));;;;取得第I个对象
(setq ssdata (entget ssn));;;;取得对象的DXF代码信息
(setq sstyp (cdr (assoc 0 ssdata)));;;取得对象的类型
(if (= sstyp "TEXT");;;如果对象类型是文字
(progn   ;;;则
(setq old_txt (assoc 1 ssdata));;取得对象包含的文字内容群码
(setq txt (cdr old_txt));;;取得对象文字内容
(chktxt);;;调用自程序转换大小写
(setq new_txt (cons 1 pp));;;将子程序产生的新文字组码
(setq ssdata (subst new_txt old_txt ssdata));;;新旧码替换
(entmod ssdata);;;;更新文字对象
)
)
(setq i (1+ i));;;记数器加一
)
)
(defun chktxt() ;判断文字,转换大小写子程序
(setq p "" pp "" n 1 key nil);;;初始化数据,
(repeat (strlen txt);;;以对象文字含字母数循环
(setq pk p);;将P赋给PK即""
(setq p (substr txt n 1));;取得文字中第N个字母
(if (= n 1) ;;;如果是第一个字母
(setq key t);;;判断量KEY为真
(if (= pk " ") (setq key t) (setq key nil));;;如果前一个字母为空格,判断量KEY为真否则为空
)
(if (= key nil);;如果KEY为空,即是说前一个字母既不是开头字母也不是空格的话
(setq pp (strcat pp (strcase p t)));;;;将它转为小写
(setq pp (strcat pp (strcase p)));;否则转为大写
)
(setq n (1+ n));;;循环加1
)
)
(princ "\n---------->> LSP_36 <<----------");;;程序结束时打印文字
(prin1) ;;;无返回推出该程序
私下认为该程序不够漂亮,有些繁琐,可以写得更漂亮些..
调用自程序最好是以参数方式调用,否则看上去有些混乱!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

发表于 2019-2-5 07:42:58 | 显示全部楼层
好,学习了。讲解很详细,希望多出这样的教程,帮助初学者成长。详细楼主
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-14 20:27 , Processed in 0.346441 second(s), 35 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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