(assoc element alist)获取所有实体autolisp

时间:2016-10-27 10:30:12

标签: autolisp

我已经谷歌搜索了一段时间,但我找不到解决方案。

我已经列出了这个名单:

((-1 . <Nome entità: 7ff5ff905910>) (0 . "DICTIONARY") (5 . "1F9") (102 . "{ACAD_REACTORS") (330 . <Nome entità: 7ff5ff9038c0>) (102 . "}") (330 . <Nome entità: 7ff5ff9038c0>) (100 . "AcDbDictionary") (280 . 0) (281 . 1) (3 . "1") (350 . <Nome entità: 7ff5ff9933c0>) (3 . "2") (350 . <Nome entità: 7ff5ff9fa0d0>) (3 . "3") (350 . <Nome entità: 7ff5ff9fa410>))

我想用dxf代码350获取所有实体。 有了这个指令,我只能得到第一个。

(assoc 350 list)

如何获得所有关联?

谢谢,丹尼斯

2 个答案:

答案 0 :(得分:1)

有多种方法可以实现这一目标 - 以下是一些例子:

(defun mAssoc1 ( key lst / rtn )
    (foreach x lst
        (if (= key (car x))
            (setq rtn (cons (cdr x) rtn))
        )
    )
    (reverse rtn)
)

(defun mAssoc2 ( key lst )
    (apply 'append
        (mapcar
            (function
                (lambda ( x ) (if (= key (car x)) (list (cdr x))))
            )
            lst
        )
    )
)


(defun mAssoc3 ( key lst )
    (mapcar 'cdr
        (vl-remove-if-not
            (function (lambda ( x ) (= key (car x))))
            lst
        )
    )
)


(defun mAssoc4 ( key lst / item )
    (if (setq item (assoc key lst))
        (cons (cdr item) (mAssoc4 key (cdr (member item lst))))
    )
)


(defun mAssoc5 ( key lst / item rtn )
    (while (setq item (assoc key lst))
        (setq rtn (cons (cdr item) rtn) lst (cdr (member item lst)))
    )
    (reverse rtn)
)


(defun mAssoc6 ( key lst )
    (mapcar 'cdr (acet-list-m-assoc key lst))
)


(defun mAssoc7 ( key lst )
    (if lst
        (if (= key (caar lst))
            (cons (cdar lst) (mAssoc7 key (cdr lst)))
            (mAssoc7 key (cdr lst))
        )
    )
) 

以下是上述功能的快速性能比较:

;;; Benchmarking: Elapsed milliseconds / relative speed for 32768 iteration(s):
;;;
;;;    (MASSOC4 2 L).....1482 / 1.25 <fastest>
;;;    (MASSOC5 2 L).....1482 / 1.25
;;;    (MASSOC6 2 L).....1498 / 1.24
;;;    (MASSOC3 2 L).....1638 / 1.13
;;;    (MASSOC7 2 L).....1747 / 1.06
;;;    (MASSOC1 2 L).....1748 / 1.06
;;;    (MASSOC2 2 L).....1856 / 1 <slowest>

答案 1 :(得分:0)

assoc只返回第一个,所以只要找不到(assoc returns nil),你需要在找到一个后循环。你应该尝试这样的代码:

(defun DXF:Dump (EntDef code / out)
    (while (setq values(assoc code EntDef))
        (setq out (append out (list (cdr values))))
        (setq EntDef(cdr(member values EntDef)))
    )
    out
)

; (setq dxfs (entget (car (entsel))))

; (DXF:Dump dxfs 350)