乐筑天下

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

[编程交流] 需要lisp帮助:删除dy

[复制链接]

73

主题

261

帖子

195

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
375
发表于 2022-7-5 15:18:03 | 显示全部楼层 |阅读模式
你好
我需要帮助解决Lisp程序的问题。
让它适应我的愿望。
它几乎成功了,我只想去掉“ensel部分”。我不需要手动选择,因为块名已经已知。
必须删除的块是Lookup1值为“1”的块“cabletype A”和“cabletype B”。
(首次加载动态块LSP)
 
 
 
提前感谢,
PmxCAD
 
  1. ;;
  2. ;;--------- Allen Johnson --------------------------------------------------------
  3. ;;
  4. ;; find dynamic blocks
  5. ;; a command line function to select all dynamic blocks
  6. ;; with the same effective name and same visibility state
  7. (defun c:test (/ en obj effname ssdb ssfvis visname visstat c)
  8. (setq en (car (entsel)))
  9. (if en
  10. (progn (setq obj (vlax-ename->vla-object en))
  11. (if (vlax-property-available-p obj 'effectivename)
  12. (progn (setq effname (vlax-get-property obj "effectivename"))
  13. ; first create a ss of the dynamic blocks with the right name
  14. (setq ssdb (ssdblk effname))
  15. ; now filter for visibility
  16. (setq ssfvis (ssadd)
  17. c 0
  18. )
  19. (setq lookupname "Lookup1")
  20. (setq lookupstat "1")
  21. (while (< c (sslength ssdb))
  22. (setq en (ssname ssdb c))
  23. (setq evstat (print (getdynprop en lookupname)))
  24. ;(if (= (strcase evstat) (strcase lookupstat))
  25. (if (= evstat (strcase lookupstat))
  26. (ssadd en ssfvis)
  27. )
  28. (setq c (1+ c))
  29. )
  30. )
  31. (prompt "\nNot a block.\n")
  32. )
  33. (command "erase" ssfvis)
  34. (princ)
  35. )
  36. )
  37. )

 
 
提前感谢,
PmxCAD
电缆类型B.dwg
dynblock。LSP
回复

使用道具 举报

rlx

21

主题

1505

帖子

1551

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
81
发表于 2022-7-5 16:04:53 | 显示全部楼层
最小测试值
  1. (defun c:tst ( / acad doc lay obj)
  2. (setq acad (vlax-get-acad-object) doc (vla-get-activedocument acad))
  3. (vlax-for lay (vla-get-layouts doc) (vlax-for obj (vla-get-block lay)
  4.    (and (vl-every '(lambda (p)(vlax-property-available-p obj p)) '(isdynamicblock effectivename))
  5.          (member (vla-get-effectivename obj) '("cabletype A" "cabletype B"))
  6.           (vl-some '(lambda (p) (and (= "Lookup1" (vla-get-propertyname p)) (eq (vlax-get p 'value) "1")))
  7.                      (vlax-invoke obj 'getdynamicblockproperties))  (vla-delete obj)))))
gr.Rlx
回复

使用道具 举报

73

主题

261

帖子

195

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
375
发表于 2022-7-5 16:31:13 | 显示全部楼层
谢谢rlx,它的作品。。。。。。。。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-14 13:04 , Processed in 1.679737 second(s), 58 queries .

© 2020-2025 乐筑天下

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