找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 793|回复: 7

[求助] [求助]:帮我找找这个程序中的语法错误

[复制链接]
发表于 2005-11-12 22:44:26 | 显示全部楼层 |阅读模式

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

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

×
帮我找找这个程序中的语法错误,它描述地是按选取的直线中点画圆,初涉lisp,问题比较浅薄,请大家指教
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-11-12 22:51:50 | 显示全部楼层
  1. [FONT=courier new](defun c:test ()
  2.   (setvar "cmdecho" 0)
  3.   (if (setq en (entsel "选取直线:"))
  4.     (progn
  5.       (setq endate (entget (car en))
  6.             x1           (car (cdr (assoc 10 endate)))
  7.             y1           (cadr (cdr (assoc 10 endate)))
  8.             x2           (car (cdr (assoc 11 endate)))
  9.             y2           (cadr (cdr (assoc 11 endate)))
  10.             m1           (/ (+ x1 x2) 2)
  11.             m2           (/ (+ y1 y2) 2)
  12.             cen           (list m1 m2)
  13.             mr           (getdist cen "\n输入半径:")
  14.       )
  15.       (command "circle" cen mr)
  16.     )
  17.   )
  18.   (princ)
  19. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2005-11-13 22:37:15 | 显示全部楼层
楼上,你每次都用if 或while 给我单写个程序,能不能针对我的lisp中的错误给分析分析,你的有些我看不懂。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 10398个

财富等级: 富甲天下

发表于 2005-11-13 23:15:06 | 显示全部楼层
最初由 gucci218 发布
[B]楼上,你每次都用if 或while 给我单写个程序,能不能针对我的lisp中的错误给分析分析,你的有些我看不懂。 [/B]

你程序中语法没有错误。
但如果未选中直线图元,其后的SETQ中因变量中没有数据会出错。所以xyp班竹的程序要加入判断。
下面是我的更改:
[php]
(defun c:mcir()
  (setvar "cmdecho" 0)
  (while (setq en (entsel "选取直线:")) ;只有选取了目标才行
   (setq endate (entget (car en)))
   (if (= (cdr (assoc 0 endate)) "LINE") (PROGN ;只有直线才行
   (setq x1 (car (cdr (assoc 10 endate))))
     (setq y1 (cadr (cdr (assoc 10 endate))))
     (setq x2 (car (cdr (assoc 11 endate))))
     (setq y2 (cadr (cdr (assoc 11 endate))))
     (setq m1 (/ (+ x1 x2) 2))
     (setq m2 (/ (+ y1 y2) 2))
     (setq cen (list m1 m2))
     (setq mr (getdist cen "\n输入半径:"))
     (command "circle" cen mr)
   ))
  )
(prin1)
)
[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

发表于 2005-11-13 23:48:26 | 显示全部楼层
还有比我菜的,可以通过测试变量的值来判断哪里出错了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-11-14 08:20:32 | 显示全部楼层
最初由 gucci218 发布
[B]楼上,你每次都用if 或while 给我单写个程序,能不能针对我的lisp中的错误给分析分析,你的有些我看不懂。 [/B]

程序错误分析对照:
  1. [FONT=courier new](defun c:mcir ()
  2.   (setvar "cmdecho" 0)
  3.   (setq en (entsel "选取直线:"))
  4.   (setq endate (entget (car en)))
  5.   ;(setq        x1 car(cdr (assoc 10 endate)));少了一对括号
  6.   (setq        x1 (car(cdr (assoc 10 endate))))
  7.   ;(setq        y1 cadr(cdr (assoc 10 endate)));少了一对括号
  8.   (setq        y1 (cadr(cdr (assoc 10 endate))))
  9.   ;(setq        x2 car(cdr (assoc 11 endate)));少了一对括号
  10.   (setq        x2 (car(cdr (assoc 11 endate))))
  11.   ;(setq        y2 cadr        (cdr (assoc 11 endate)));少了一对括号
  12.   (setq        y2 (cadr        (cdr (assoc 11 endate))))
  13.   (setq m1 (/ (+ x1 x2) 2))
  14.   (setq m2 (/ (+ y1 y2) 2))
  15.   (setq cen (list m1 m2))
  16.   (setq mr (getdist cen "\n输入半径:"))
  17.   (command "circle" cen mr)
  18.   (prin1)
  19. )[/FONT]

简化版
  1. [FONT=courier new](load "xyp_lib")
  2. ;|加载通用函数(可在签名栏直接下载)
  3. 如果已经下载xyp_lib并放到搜索路径下可以不再下载!
  4. 利用以下任何一种方式(首选第一种)即可加载和运行通用函数内的所有子程序:
  5. ★1·在acad.lsp中增加(load"xyp_lib")
  6. ■2·在每个程序内增加(load"xyp_lib")
  7. ■3·在command下,输入(load"xyp_lib")
  8. ■4·在菜单.mnl中增加(load"xyp_lib")
  9. ■5·将xyp_lib.vlx文件直接拽到cad屏幕
  10. [COLOR=red] ★通用函数下载地址:[/COLOR]
  11. [url]http://www.xdcad.net/forum/attachment.php?s=&postid=1606661[/url]
  12. |;
  13. (defun c:test ()
  14.   (cmdla0)
  15.   (setq        s1  (car (usel1 0 "LINE" "LINE线")) ;确保选择line线
  16.         pt1 (cdr (assoc 10 (entget s1))) ;取得起点
  17.         pt2 (cdr (assoc 11 (entget s1))) ;取得终点
  18.         cen (xyp-get-MidPoint pt1 pt2)        ;取得中点
  19.         mr  (UREAL 7 "" "\n输入半径" mr) ;半径
  20.   )
  21.   (command "circle" cen mr)
  22.   (cmdla1)
  23. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-15 11:44 , Processed in 0.366620 second(s), 46 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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