找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 879|回复: 1

[LISP程序]:那位大侠帮小弟看一看我的lisp语句错在哪里

[复制链接]
发表于 2006-11-2 14:00:26 | 显示全部楼层 |阅读模式

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

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

×
小弟编了一个小程序,用来将数字文本进行+、*运算并替换掉旧文本,可程序运行有错啊,哪位大侠救救我。

(defun c:WBYS()
;;批量修改文本。
(prompt "\n选择需要修改的文本")
(setq ss (ssget))

(setq ss1 (ssadd))                 ;对选择集进行筛选,选择其中的text或mtext
(setq n (sslength ss))
(setq k 0)
(repeat n
    (if (or (= "TEXT" (cdr (assoc 0 (entget (ssname ss k))))) (= "MTEXT" (cdr (assoc 0 (entget (ssname ss k))))) )
      (progn
        (setq a (ssname ss k))
        (ssadd a ss1)
      )
    )
  (setq k (+ k 1))
)

(setq c (getstring "\n请选择要执行的操作(+ 加法;* 乘法)\n"))
(setq shuzi (getreal "\n请输入运算数\n"))

(setq k 0)
( if(= c "*")
  (progn
    (
     (repeat (sslength ss1)
       (setq namet (ssname ss1 k))
       (setq elt (entget namet))
         (SETQ temp (atof (cdr (assoc 1 elt))))
         (setq temp1 (* temp shuzi))
         (setq temp (rtos temp1 3))
         (setq elt (subst (cons 1 temp) (assoc 1 elt) elt ))
         (entmod elt)
        )
    )
   )
)

( if(= c "+")
  (progn
    (
     (repeat (sslength ss1)
       (setq namet (ssname ss1 k))
       (setq elt (entget namet))
         (SETQ temp (atof (cdr (assoc 1 elt))))
         (setq temp1 (+ temp shuzi))
         (setq temp (rtos temp1 3))
         (setq elt (subst (cons 1 temp) (assoc 1 elt) elt ))
         (entmod elt)
        )
    )
   )
)
      

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

  1. (defun c:WBYS ()
  2.   ;;批量修改文本。
  3.   (prompt "\n选择需要修改的文本")
  4.   (setq ss (ssget '((0 . "TEXT,MTEXT")));;;----------------繁
  5.         c (getstring "\n请选择要执行的操作(+ 加法;* 乘法)\n")
  6.         shuzi (getreal "\n请输入运算数\n");;;----应该加缺省
  7.         k 0)
  8.   (if (= c "*");;;---------------progn没必要,再(错
  9.        (repeat (sslength ss)
  10.          (setq namet (ssname ss k) k(1+ k);;;------------漏
  11.                elt (entget namet))
  12.          (SETQ temp (atof (cdr (assoc 1 elt))))
  13.          (setq temp1 (* temp shuzi))
  14.          (setq temp (rtos temp1 2 3));;;------------错
  15.          (setq elt (subst (cons 1 temp) (assoc 1 elt) elt))
  16.          (entmod elt)
  17.        )
  18.   )

  19.   (if (= c "+");;;以下自己改
  20.     (progn
  21.        (repeat (sslength ss)
  22.          (setq namet (ssname ss k))
  23.          (setq elt (entget namet))
  24.          (SETQ temp (atof (cdr (assoc 1 elt))))
  25.          (setq temp1 (+ temp shuzi))
  26.          (setq temp (rtos temp1 3))
  27.          (setq elt (subst (cons 1 temp) (assoc 1 elt) elt))
  28.          (entmod elt)
  29.        )
  30.     )
  31.   )


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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-23 12:59 , Processed in 0.396670 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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