txt
Ответы в темах
-
АвторСообщения
-
как известно, при использовании set(list) мы преобразуем исходный список во множество , то есть элементы становятся неупорядоченными (в сравнении с исходным списком) и уникальными.
Один из способов сохранить порядок исходного списка с уникальными элементами:
(для сравнения используем также set):
inn = [9,8,8,7,5,5,7]
set=set(inn)
set_save_order=[ els for indx,els in enumerate(inn) if inn.index(els)==indx ]
OUT = set, set_save_orderp.s.
обратная задача выполняется уже в транзакции:import clr
clr.AddReference("RevitServices")
import RevitServices
from RevitServices.Persistence import DocumentManager
from RevitServices.Transactions import TransactionManager
doc = DocumentManager.Instance.CurrentDBDocument
clr.AddReference("RevitAPI")
import Autodesk
from Autodesk.Revit.DB import *
TransactionManager.Instance.EnsureInTransaction(doc)
OUT=[[WallUtils.AllowWallJoinAtEnd(i, 1), WallUtils.AllowWallJoinAtEnd(i, 0)] for i in UnwrapElement(IN[0]) ]
TransactionManager.Instance.TransactionTaskDone()здесь на форуме это есть , повторюсь:
Скопируйте в питон это:
https://yadi.sk/i/OgERC3W03N3yzV
работает это так:
Вот еще решения (не мои, выкладываю с разрешения автора):
+ для решения с двумя группировками
Вопрос:Возможно как то сгруппировать одинаковые элементы по названию (индексу [0] в подсписке) и сложить их значения по индексу [1] (100+100+100, 200+200) (без использования библиотек Numphy и Scipy ) ?
Решение:
Спасибо!
все работает:import clr
clr.AddReference('RevitAPI')
from Autodesk.Revit.DB import *
clr.AddReference('RevitNodes')
import Revit
clr.AddReference('RevitServices')
import RevitServices
from RevitServices.Persistence import DocumentManager
from RevitServices.Transactions import TransactionManager
doc = DocumentManager.Instance.CurrentDBDocument
TransactionManager.Instance.EnsureInTransaction(doc)
delete_els=[doc.Delete(UnwrapElement(i).Id) for i in IN[0]]
TransactionManager.Instance.TransactionTaskDone() -
АвторСообщения