明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1727|回复: 3

[已解答] 请各位帮忙修改下此代码

[复制链接]
发表于 2014-8-3 15:42:32 | 显示全部楼层 |阅读模式
2明经币
本帖最后由 王与韩1 于 2014-8-3 23:13 编辑

先谢谢各位的关注,这是在论坛上找到了同行业的兄弟的代码,但是希望能改进一点,效果如图

程序如下
(defun c:cs( )
(setvar "cmdecho" 0)
(setq dlq '("16" "20" "25" "32" "40" "50"))
(setq xj '("2.5" "4" "6" "10" "16" "16"))
(setq gj '("20" "20" "20" "25" "32" "32"))
(setq 1gj '("20" "20" "20" "25" "32" "32"))
(setvar "cmdecho" 0)
(prompt "\n选择文字:")
(setq ss (ssget '((0 . "TEXT"))))
(repeat (setq i (sslength ss))
(setq en (entget(ssname ss (setq i (1- i)))))
(setq zb (cdr(assoc 10 en)));坐标
(setq tx (cdr(assoc 1 en)))
(if (setq dl (member tx dlq)) (progn
  (setq n (- (length dlq) (length dl)))
  (setq txt (strcat "BV-3*" (nth n xj) "-JDG" (nth n gj)));SC和JDG希望能选择
  (setq newzb (mapcar '- zb '(600 0 0)))
  (setq en (subst (cons 1 txt) (assoc 1 en) en))
  (entmake (cdr(subst (cons 10 newzb) (assoc 10 en) en)))
  (setq txt1 (strcat "34" (nth n 1gj)));“34”处为输入的断路器名
  (setq newzb1 (mapcar '- zb '(1000 100 0)))
  (setq en (subst (cons 1 txt1) (assoc 1 en) en))
  (entmake (cdr(subst (cons 10 newzb1) (assoc 10 en) en)))
))
)
(setvar "cmdecho" 1)
(princ)
)

希望添加的功能:1.提示输入套管类型,如JDG和SC(不同管型后数字不同)。2.提示输入断路器品牌(替换程序中的“34”)
输入选项后效果如下(JPG改为SC,34改为了XL)attach]8893[/attach]



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

最佳答案

查看完整内容

是否对每个图元都提示呢?下面是所有图元都一致的程序

点评

原始数据错误:(setq dlq '("1" "20" "25" "32" "40" "50"))  发表于 2014-8-3 19:19
发表于 2014-8-3 15:42:33 | 显示全部楼层
本帖最后由 ZZXXQQ 于 2014-8-4 07:52 编辑

是否对每个图元都提示呢?下面是所有图元都一致的程序
  1. (defun c:cs( )
  2. (setvar "cmdecho" 0)
  3. (setq dlq '("16" "20" "25" "32" "40" "50"))
  4. (setq xj '("2.5" "4" "6" "10" "16" "16"))
  5. (setq gj '("20" "20" "20" "25" "32" "32"))
  6. (setq 1gj '("20" "20" "20" "25" "32" "32"))
  7. (initget "JDG SC" 1)
  8. (setq gx (getkword "\n选择管型: "))
  9. (setq pp (if (= gx "JDG") "34" "XL"))
  10. (prompt "\n选择文字:")
  11. (setq ss (ssget '((0 . "TEXT"))))
  12. (repeat (setq i (sslength ss))
  13. (setq en (entget(ssname ss (setq i (1- i)))))
  14. (setq zb (cdr(assoc 10 en)));坐标
  15. (setq tx (cdr(assoc 1 en)))
  16. (if (setq dl (member tx dlq)) (progn
  17.   (setq n (- (length dlq) (length dl)))
  18.   (setq txt (strcat "BV-3*" (nth n xj) gx (nth n gj)));SC和JDG希望能选择
  19.   (setq newzb (mapcar '- zb '(600 0 0)))
  20.   (setq en (subst (cons 1 txt) (assoc 1 en) en))
  21.   (entmake (cdr(subst (cons 10 newzb) (assoc 10 en) en)))
  22.   (setq txt1 (strcat pp (nth n 1gj)));“34”处为输入的断路器名
  23.   (setq newzb1 (mapcar '- zb '(1000 100 0)))
  24.   (setq en (subst (cons 1 txt1) (assoc 1 en) en))
  25.   (entmake (cdr(subst (cons 10 newzb1) (assoc 10 en) en)))
  26. ))
  27. )
  28. (setvar "cmdecho" 1)
  29. (princ)
  30. )
回复

使用道具 举报

 楼主| 发表于 2014-8-3 19:58:06 | 显示全部楼层
额,没错啊,刚才试了下,能用的
回复

使用道具 举报

 楼主| 发表于 2014-8-4 08:58:35 | 显示全部楼层
本帖最后由 王与韩1 于 2014-8-4 09:08 编辑
ZZXXQQ 发表于 2014-8-4 07:47
是否对每个图元都提示呢?下面是所有图元都一致的程序

"34","XL"那里也要自己输入的,不过看程序我大概会了.
  • (setq dlq '("16" "20" "25" "32" "40" "50"))
  • (setq xj '("2.5" "4" "6" "10" "16" "16"))
  • (setq gj '("20" "20" "20" "25" "32" "32"))
  • (setq 1gj '("20" "20" "20" "25" "32" "32"))
    中的dlq那一行怎么改成"1~16","16~20","20~25","25~32","32~40","40~50"之间的整数与下面xj,gj这些对应呢,边求程序边学习,谢谢了



回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 13:40 , Processed in 0.267963 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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