乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 2|回复: 2

[编程交流] 我的Lisp程序怎么了?

[复制链接]

33

主题

96

帖子

65

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
170
发表于 2022-7-6 07:44:22 | 显示全部楼层 |阅读模式
我想我可以做到这一点,但由于某种原因,我得到了这个错误。
“错误:错误的参数类型:stringp(3.0”x“11.25)”
我试图用它们的宽度、厚度标记我的多段线,并在中间添加字母x在中间。
  1. (defun c:pt (/ layerset hr raf1 raf2 ss en ed p10 p11 mpt d2d d1d d3d d4d lan tan fg hg)
  2. (defun errorhandler (s)
  3. (if (/= s "Function cancelled")
  4.    (princ (strcat "\nError: " s))
  5.    (princ "SW function cancelled!"))
  6. (setvar "clayer" layerset)
  7. (setvar "orthomode" orthoset)
  8. (setvar "osmode" osset)
  9. (setvar "cmddia" cmddiaset)
  10. (setvar "attdia" attdiaset)
  11. (setvar "regenmode" 1)
  12. (setq *error* olderr)
  13. (princ))
  14. (setq layerset (getvar "clayer"))
  15. ;----------PICK WHICH LINES YOU WANT TO LABEL-------------  
  16. (setq hr (getstring "\nFlush/Drop Beam or Header?(f/h): "))
  17.   (if (= hr "f")
  18.     (progn
  19.   (command "_.layer" "s" "s-frm-beam" "off" "*" "n" "on" "s-anno-text" "s" "s-anno-text" "" "")))
  20.     (if (= hr "h")
  21.       (progn
  22. (command "_.layer" "s" "s-frm-header" "off" "*" "n" "on" "s-anno-text" "s" "s-anno-text" "" "")))
  23.   (command "textsize" "6" "")
  24. (command "_.style" "jaytxt" "romans" "0" "0.80" "" "" "" "")
  25. (and (setq ss (ssget '((0 . "*polyline"))))
  26.     (while (setq en (ssname ss 0))
  27.            (setq ed (entget en))
  28.            (setq p10 (cdr (assoc 10 ed)))
  29.            (setq p9 (reverse ed))
  30.            (setq p11 (cdr (assoc 10 p9)))
  31.            (setq mpt (mapcar '(lambda (a b) (* (+ a b) 0.5)) p10 p11))
  32.            (setq ltype (cdr (cond ((assoc 6 ed)))))
  33.            (setq depth (cdr (cond ((assoc 39 ed)))))
  34.            (setq width (cdr (cond ((assoc 40 ed)))))
  35.            ;(if (= width "1.75") (setq w1 1.75))
  36.            ;(if (= width "3") (setq w1 2))
  37.            ;(if (= depth "9.25") (setq d1 9.25))
  38.            ;(if (= depth "11.25") (setq d1 12))
  39.       (setq label (list width"x"depth))
  40. (defun radians->degrees (r)(cvunit r "radian" "degree"))
  41. ;-------TEXT JUSTIFICATION----------------------------------------     
  42.       (setq lan (angle p10 p11))
  43. (setq ad (radians->degrees lan))   
  44.       (if (and (> ad 90.1) (<= ad 270.1))
  45.         (progn
  46.           (setq ptemp p10)
  47.           (setq p10 p11)
  48.           (setq p11 ptemp)
  49.           (setq lan (angle p10 p11))      
  50.           (setq ad (radians->degrees lan))))
  51.       (setq dir (if (< (* pi 0.5) lan (* pi 1.5)) - +))
  52.            (setq r3(entmake (list (cons 0 "TEXT")
  53.                           (cons 8 (getvar "CLAYER"))
  54.                           (cons 7 (getvar "TEXTSTYLE"))
  55.                           (cons 40 (getvar "TEXTSIZE"))
  56.                           (cons 41 0.80)
  57.      (cons 72 4)
  58.             (setq fg(cons 10 (setq r1(polar mpt (dir lan (+ 1))
  59.                                    (getvar "TEXTSIZE")))))
  60.                           (setq hg(cons 11 (setq r2(polar mpt (dir lan (+ 1))
  61.                                    (getvar "TEXTSIZE")))))
  62.                           (setq gg(cons 50 lan))
  63.                          (setq rg(cons 1 (strcat label))))))
  64.                   (ssdel en ss)))
  65. (command "_.layer" "on" "*" "" "")
  66. (setvar "clayer" layerset)
  67.   (prin1))
回复

使用道具 举报

44

主题

3166

帖子

2803

银币

中流砥柱

Rank: 25

铜币
557
发表于 2022-7-6 08:32:29 | 显示全部楼层
考虑宽度和深度变量的数据类型,然后查看STRCAT参数。
 
提示-查看RTOS功能。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 09:11:52 | 显示全部楼层
strcat函数不会将列表转换为字符串,而是连接两个或多个字符串。
 
您需要使用rtos函数将实数(数值)转换为字符串,然后在将字符串提供给DXF组码1之前,使用strcat连接生成的字符串。
 
此外,未定义变量orthoset、osset、cmddiaset和attdiaset,因此在计算时会导致错误处理程序遇到错误。尽管如此,错误处理程序永远不会计算,因为您没有重新定义*错误*符号。
 
还有,为什么在这里使用cond语句?
 
  1. (setq ltype (cdr (cond ((assoc 6 ed)))))
  2. (setq depth (cdr (cond ((assoc 39 ed)))))
  3. (setq width (cdr (cond ((assoc 40 ed)))))

 
如果可以找到DXF组,则该值将由assoc函数返回,否则assoc函数将返回nil。cond的使用是完全冗余的。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-9 23:02 , Processed in 0.392465 second(s), 69 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表