设为首页收藏本站

晓东CAD家园-论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 171|回复: 3

[每日一码] 跨文档取数据,跨dwg取数据

[复制链接]
发表于 2020-7-6 22:06:35 | 显示全部楼层 |阅读模式

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

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

x
  1. (defun $get-obj-i-doc$
  2.        (doc-i filter LST / ax:BuildFilter dc sss ss tmp ent data)
  3.                                         ;  这个函数是跨文档读取块参照
  4.                                         ; filter 过滤器,例如 (list '(0 . "INSERT") '(2 . "模块*"))
  5.                                         ;  ($get-obj-v-all$ 1)
  6.   (setq        dc (vl-catch-all-apply
  7.              'vla-item
  8.              (list (vla-get-documents (vlax-get-acad-object)) doc-i)
  9.            )
  10.   )
  11.   (if (not (vl-catch-all-error-p dc))
  12.     (progn
  13.       (setq sss (vl-catch-all-apply 'VLA-GET-SelectionSets (list dc)))
  14.       (if (not (vl-catch-all-error-p sss))
  15.         (progn
  16.           (if (vl-catch-all-error-p
  17.                 (vl-catch-all-apply 'vla-item (list sss "new1"))
  18.               )
  19.             nil
  20.             (vl-catch-all-apply
  21.               'vla-delete
  22.               (list (vl-catch-all-apply 'vla-item (list sss "new1")))
  23.             )
  24.           )
  25.           (setq ss (vl-catch-all-apply 'vla-add (list sss "new1")))
  26.           (if (not (vl-catch-all-error-p ss))
  27.             (progn
  28.               (setq
  29.                 tmp (mapcar
  30.                       (function        (lambda        (lst typ)
  31.                                   (vlax-make-variant
  32.                                     (vlax-safearray-fill
  33.                                       (vlax-make-safearray
  34.                                         typ
  35.                                         (cons 0 (1- (length lst)))
  36.                                       )
  37.                                       lst
  38.                                     )
  39.                                   )
  40.                                 )
  41.                       )
  42.                       (list (mapcar 'car filter) (mapcar 'cdr filter))
  43.                       (list vlax-vbInteger vlax-vbVariant)
  44.                     )
  45.               )
  46.               (vla-select
  47.                 ss
  48.                 acSelectionSetAll
  49.                 nil
  50.                 nil
  51.                 (car tmp)
  52.                 (cadr tmp)
  53.               )
  54.               (vlax-for ent ss (setq data (cons ent data)))
  55.               (vl-catch-all-apply 'vla-delete (list ss))
  56.               (if data
  57.                 (setq data (reverse data))
  58.               )
  59.             )
  60.           )
  61.         )
  62.       )
  63.     )
  64.   )
  65.   data
  66. )
  67. (setq data ($get-obj-i-doc$ 0 '((0 . "INSERT") (2 . "模块*")) NIL))
  68. (setq
  69.   datas        (mapcar        (function
  70.                   (lambda (obj / vs tbl v)
  71.                     (if        (and (setq v
  72.                                     (vl-catch-all-apply
  73.                                       'vlax-variant-value
  74.                                       (list (vla-GetAttributes obj))
  75.                                     )
  76.                              )
  77.                              (not (vl-catch-all-error-p v))
  78.                              (setq tbl (vl-catch-all-apply
  79.                                          'vlax-safearray->list
  80.                                          (list v)
  81.                                        )
  82.                              )
  83.                              (not (vl-catch-all-error-p tbl))
  84.                         )
  85.                       (setq vs (mapcar
  86.                                  (function
  87.                                    (lambda (x)
  88.                                      (cons (vla-get-tagstring x)
  89.                                            (vla-get-textstring
  90.                                              x
  91.                                            )
  92.                                      )
  93.                                    )
  94.                                  )
  95.                                  tbl
  96.                                )
  97.                       )
  98.                     )
  99.                     vs
  100.                   )
  101.                 )
  102.                 data
  103.         )
  104. )
  105. (setq datas (vl-remove nil datas))
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 19个

财富等级: 恭喜发财

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

使用道具 举报

已领礼包: 275个

财富等级: 日进斗金

发表于 4 天前 | 显示全部楼层
感谢楼主分享跨文档取数据,跨dwg取数据
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 94个

财富等级: 招财进宝

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2021-4-11 18:45 , Processed in 0.374218 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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