Перейти к публикации

значения переменных в макросе из 3d модели


алексей556

Рекомендованные сообщения

Подскажите как получить в макросе значения переменных, описанных в SW property tab builder для 3д модели?

Ссылка на сообщение
Поделиться на других сайтах


Не ясен вопрос.

Вот кусочек содержимого файла таббилдера:     

<Control Label="Разработал" PropName="Разраб." ApplyTo="Global" Type="ComboBox" UserDefineable="True">
        <Data Range="A1:A100" SheetIndex="1" Path="D:\Шаблоны SolidWorks 2016\Свойства пользователя\Поле разработал.xls" SourceType="Excel" />
      </Control>

Ссылка на сообщение
Поделиться на других сайтах

Подскажите как получить в макросе значения переменных, из 3д модели? Задача сделать макрос сохранения файла с номером версии. т.е. в макросе надо получить значение переменной Revision

Screenshot_1.png

Ссылка на сообщение
Поделиться на других сайтах

Задача сделать макрос сохранения файла с номером версии. т.е. в макросе надо получить значение переменной Revision

Screenshot_1.png

Ссылка на сообщение
Поделиться на других сайтах

А где в ТабБильдере эта переменная "Ревизия"?

В скрине Вы приводите набор переменных чертежа, а в первом сообщении речь шла о 3Д модели.

В торговле, я помню, был такой термин "Ревизия". А в ЕСКД кроме "Номер изменения" мне ничего не приходит в голову. Попробую проанализировать эту "Ревизию" в своих файлах - чем же она интересна?

Если говорить о "Номере изменения", но у меня в каждой 3Д модели есть такая переменная (и номер извещения тоже) и я ее использую где хочу - в том числе добавляю в конец имени файла при сохранении. Но заполняю в 3Д модели  вручную.

Ссылка на сообщение
Поделиться на других сайтах
23 минуты назад, VOleg сказал:

А где в ТабБильдере эта переменная "Ревизия"?

В скрине Вы приводите набор переменных чертежа, а в первом сообщении речь шла о 3Д модели.

В торговле, я помню, был такой термин "Ревизия". А в ЕСКД кроме "Номер изменения" мне ничего не приходит в голову. Попробую проанализировать эту "Ревизию" в своих файлах - чем же она интересна?

Если говорить о "Номере изменения", но у меня в каждой 3Д модели есть такая переменная (и номер извещения тоже) и я ее использую где хочу - в том числе добавляю в конец имени файла при сохранении. Но заполняю в 3Д модели  вручную.

просто так назвали переменную. это номер версии, которую заполняю в 3д модели вручную. вопрос как ее вытащить в макрос и использовать для добавления к имени файла.

макрос по кнопочке делает dwg в нужную папку см.вложение

Screenshot_2.png

 

Macro_dwg.zip

Изменено пользователем алексей556
изменил
Ссылка на сообщение
Поделиться на других сайтах

Если есть переменная, то в макросе ее легко получить - мне программисты вставляли все, что я хотел. Сам-то я в это не лезу.

Однако, я стараюсь иностранными словами не пользоваться.

Вот какой перевод дал интернет слова "Revision"

А Вы говорите, что у Вас это "версия".

А вот что означает "версия" в SWE PDM? Но это у них не "изменение".

 

Версия.PNG

Ссылка на сообщение
Поделиться на других сайтах

VOleg, так все же каким оператором (кодом) можно получить значение в макросе из атрибута свойства пользователя. Подскажите, или пришлите образец макроса где вы добавляете "номер извещения в конец имени файла"

Ссылка на сообщение
Поделиться на других сайтах

- Подскажите, а каким образом из сотен деталей и сборок на чертеже надо выбрать нужную (деталь), чтоб потом макросом обработать?

- Подскажите, а куда будет вноситься информация о "номере версии"?

- Подскажите, а что будет если "переменной" "Revision" не окажется в файле?

- Подскажите, а "задачу сделать макрос" вы кому ставите? )))

 

Ссылка на сообщение
Поделиться на других сайтах
22 часа назад, алексей556 сказал:

Задача сделать макрос сохранения файла с номером версии. т.е. в макросе надо получить значение переменной Revision

Вот как раз под рукой оказалось:

Цитата

Dim swApp As Object

Dim ModelDoc As ModelDoc2

Set swApp = Application.SldWorks

Set ModelDoc = swApp.ActiveDoc

MsgBox ModelDoc.Extension.CustomPropertyManager("").Get("Revision")

InputBox
Debug.Print ModelDoc.Extension.CustomPropertyManager("").Set("Revision", InputBox( "введите новое значение или Inbox замените переменной с нужной цифрой"))

Если данного свойства нет, то надо его добавить:  ModelDoc.Extension.CustomPropertyManager("").Add...

Или во все шаблоны добавить, что бы нужное свойство было во всех шаблонах. Но если данного свойства нет, то оно не скорректируется и не покажется.

Изменено пользователем Kelny
Ссылка на сообщение
Поделиться на других сайтах
21 час назад, Kelny сказал:

Вот как раз под рукой оказалось:

Если данного свойства нет, то надо его добавить:  ModelDoc.Extension.CustomPropertyManager("").Add...

Или во все шаблоны добавить, что бы нужное свойство было во всех шаблонах. Но если данного свойства нет, то оно не скорректируется и не покажется.

Спасибо, работает, могу получить свойства с чертежа, но там нет требуемого (Revision), оно прописано в 3д модели в конкретной конфигурации (см.изображение). Макрос вызывается с чертежа (для автом. сохранения в dwg). Вопрос как его получить в свойствах на чертеже (см. изображение)? или как его добавить/прописать в макросе если можно поподробней.Screenshot_3.png.d1fc47e48847a62b6640dc30ba915fbd.pngScreenshot_4.png.9f68f9ef073e91fa10154d890d825d0c.png

Ссылка на сообщение
Поделиться на других сайтах

 

1 час назад, алексей556 сказал:

нет требуемого (Revision), оно прописано в 3д модели в конкретной конфигурации (см.изображение). Макрос вызывается с чертежа (для автом. сохранения в dwg). Вопрос как его получить в свойствах на чертеже (см. изображение)? или как его добавить/прописать в макросе если можно поподробней.

Не нужен для этого макрос, надо просто в заметке листа или свойстве чертежа добавить ссылку: $PRPSHEET:"Revision"

Если свойство с таким именем (в вашем случае Revision) будет в закладке КОНФИГУРАЦИИ и в закладке НАСТРОЙКИ, то будет взято значение из закладки НАСТРОЙКИ.

Ссылка на сообщение
Поделиться на других сайтах
27 минут назад, Kelny сказал:

 

Не нужен для этого макрос, надо просто в заметке листа или свойстве чертежа добавить ссылку: $PRPSHEET:"Revision"

Если свойство с таким именем (в вашем случае Revision) будет в закладке КОНФИГУРАЦИИ и в закладке НАСТРОЙКИ, то будет взято значение из закладки НАСТРОЙКИ.

Не работает: если ставлю тип "текст", то вычисленное значение остается $PRPSHEET:"Revision", если ставлю тип "номер", то пишет недопустимое значение. А на чертеже значение определяет. что не так?Screenshot_5.thumb.png.db17355ad3dca7b1221b0ed75f4d9c61.png

Ссылка на сообщение
Поделиться на других сайтах
22 минуты назад, алексей556 сказал:

Не работает: если ставлю тип "текст", то вычисленное значение остается $PRPSHEET:"Revision"

Так и должно быть. После этого на чертеже вместо ссылки $PRPSHEET:"Revision" уже ссылка на свойства файла $PRP:"Revision" и в заметке будет ваша ревизия.

 

23 минуты назад, алексей556 сказал:

А на чертеже значение определяет. что не так?

Всё так, просто окно свойств не обсчитывает такие ссылки (это уже вопрос  к разработчикам, почему эти ссылки не выдают значение в графу вычисленного значения), но после добавления в заметку данного свойства всё пересчитается в значение по ссылке.

Ссылка на сообщение
Поделиться на других сайтах
55 минут назад, Kelny сказал:

Так и должно быть.

в макросе в результате считывает значение как текст "$PRPSHEET:"Revision", а не требуемое число.

Screenshot_6.png.5c595e11230275ea94852bccaf5e2761.png

Ссылка на сообщение
Поделиться на других сайтах
2 часа назад, алексей556 сказал:

в макросе в результате считывает значение как текст "$PRPSHEET:"Revision", а не требуемое число.

Читайте заметку со ссылкой, получите требуемое число.

В ранних версиях другого способа не нашёл поэтому вставлял заметку с требуемой ссылкой, считывал значение и удалял заметку (может в новых версиях по другому или в старых версиях не доглядел чего):

Set swNote = ModelDoc2.InsertNote("$PRPSHEET:" & Chr(34) & "Revision")
swNote.SetName ("Temp_Note")
MsgBox  swNote.GetText
ModelDoc2.Extension.SelectByID2 "Temp_Note@" & swDraw.GetSheetNames(0), "NOTE", 0, 0, 0, False, 0, Nothing, 0
ModelDoc2.EditDelete

 

Изменено пользователем Kelny
Ссылка на сообщение
Поделиться на других сайтах
В ‎18‎.‎10‎.‎2017 в 14:10, алексей556 сказал:

номер версии, которую заполняю в 3д модели вручную. вопрос как ее вытащить в макрос и использовать для добавления к имени файла.

Можно так:

Скрытый текст

Sub main()

Dim swApp As SldWorks.SldWorks
Dim Part As SldWorks.ModelDoc2
    
    Dim swDraw                      As SldWorks.DrawingDoc
    Dim swView                      As SldWorks.View
    Dim swCustProp                  As CustomPropertyManager
    Dim Rev                         As String

Dim FilePath As String
Dim PathSize As Long
Dim PathNoExtension As String
Dim NewFilePath As String
Dim sPath As String
Dim sName As String



Set swApp = Application.SldWorks
Set Part = swApp.ActiveDoc

If Part.GetType = swDocASSEMBLY Or Part.GetType = swDocPART Then
    MsgBox "Откройте чертёж."
    Exit Sub
End If
        
Dim swModel                     As SldWorks.ModelDoc2
    
    Set swDraw = swApp.ActiveDoc
    Set swView = swDraw.GetFirstView
    Set swView = swView.GetNextView
    Set swModel = swView.ReferencedDocument
    
    Set swCustProp = swModel.Extension.CustomPropertyManager("")
        swCustProp.Get2 "Revision", 30, Rev
    Set swCustProp = Part.Extension.CustomPropertyManager("")
        swCustProp.Add2 "Revision", 30, Rev
   

FilePath = Part.GetPathName

    i = Len(FilePath)
    Do While Mid(FilePath, i, 1) <> "\"
      i = i - 1
    Loop
    sPath = Left(FilePath, i) 'путь без имени файла
    sName = Mid(FilePath, i + 1) 'имя файла
    sNameNoExtension = Left(sName, Len(sName) - 7) 'имя файла без расширения (обрезали .slddrw)

PathSize = Strings.Len(FilePath)

NewFilePath_dwg = "d:\" & sNameNoExtension & " - Версия " & Rev & ".dwg"

Part.SaveAs2 NewFilePath_dwg, 0, True, False

MsgBox "Готово"

End Sub

 

 

Изменено пользователем Kir95
Ссылка на сообщение
Поделиться на других сайтах
В 20.10.2017 в 19:55, Kir95 сказал:

Set swCustProp = swModel.Extension.CustomPropertyManager("") swCustProp.Get2 "Revision", 30, Rev Set swCustProp = Part.Extension.CustomPropertyManager("") swCustProp.Add2 "Revision", 30, Rev

не берет значение из переменной Revision (см. скрин)Screenshot_7.png.60455de17ab2790a92b59d95061ed4dd.png

Ссылка на сообщение
Поделиться на других сайтах
7 часов назад, алексей556 сказал:

не берет значение из переменной Revision (см. скрин)

Напишите MsgBox "Версия-" + Rev, получите окно с номером версии из модели, но если всё-таки:

 

В ‎18‎.‎10‎.‎2017 в 12:56, алексей556 сказал:

Задача сделать макрос сохранения файла с номером версии.

то достаточно создать новый макрос и вставить в него код из предыдущего поста (перед вставкой очистите содержимое, которое создаётся автоматически). Получите двг файл с номером версии (Revision).

Солид какого года у вас?

версия -1.JPG

Ссылка на сообщение
Поделиться на других сайтах

Присоединяйтесь к обсуждению

Вы можете опубликовать сообщение сейчас, а зарегистрироваться позже. Если у вас есть аккаунт, войдите в него для написания от своего имени.
Примечание: вашему сообщению потребуется утверждение модератора, прежде чем оно станет доступным.

Гость
Ответить в тему...

×   Вставлено в виде отформатированного текста.   Вставить в виде обычного текста

  Разрешено не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отобразить как ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

  • Сейчас на странице   0 пользователей

    Нет пользователей, просматривающих эту страницу.




  • Сообщения

    • MagicNight
      Да дело не в бедности, ищу оптимальный ноут, пока не могу найти.
    • Bot
      АСКОН объявляет о старте открытого бета-тестирования новой версии КОМПАС-3D и приложений. Коммерческая версия КОМПАС-3D v23 выйдет летом 2024 года, но уже сейчас испытать новинки может любой желающий. Бета-тестирование — это проверка новой функциональности в «полевых» условиях, когда пользователи знакомятся с нововведениями на собственных проектах и сценариях работы, а также проверяют совместимость со своим программно-аппаратным обеспечением. Новая версия создавалась в соответствии с дорожной картой АСКОН для задач проектирования изделий высокотехнологичных отраслей и стала еще более функциональной и производительной. При разработке учитывались предложения пользователей по темам трехмерного моделирования, подготовки чертежей и спецификаций, приложений для машиностроения, приборостроения и строительства. Бета-версия КОМПАС-3D открыта для всех. Дистрибутив предоставляется бесплатно на время проведения тестирования. *** Период проведения бета-тестирования: с 6 [...] View the full article
    • fenics555
      Уважаемые Дамы и Господа!  Есть библиотечные изделия, которые почему-то очень доооооолго грузятся в сборках. Я хочу попросить Вас потестить их и сказать в чем причина, ибо совсем невозможно работать. gost18829-73.prt.1 pin_split.prt.1 Как это всё можно ускорить?
    • gudstartup
      а вы хоть станок проверяли по программе на изделии на точность прежде чем товарищей этих выгнать? если нет то грешите на самих себя! система в наших краях еще не распространенная поэтому и тем тут нет надо в поднебесную писать
    • AlexArt
      Ну допустим, ты и на другом ресурсе это опубликовал. А не коммуниздил. Но вот продвигать воровство от государства, ворующее из Вики, это верх мерзости.
    • maxx2000
      Ах, да. Фильтры выбора добавили. Теперь можно выбрать только то что видно на первом плане, а не вместе с тем что с обратной стороны детали. В общем надо обновляться. Как раз работёнка на прессформу нарисовалась 
    • maxx2000
      Причина того - Кроилово. Кроилово всегда приводит к попадалову. Месяц простоял сколько мильонов деревянных потеряли? Вопрос риторический. И ещё будет стоять. Как памятник человеческой глупости и жадности.
    • AlexKaz
      "9 июля 1968 года на мышах был проведен самый знаменитый эксперимент американского ученого-этолога Джона Кэлхуна «Вселенная-25». Суть опыта заключалась в создании идеальных условий, где мыши могли бы жить и размножаться, не ведая никаких забот, вдали от хищников и в отсутствие эпидемий и заболеваний. Для этих целей ученый построил специальный загон, куда были помещены четыре пары белых мышей (самцов и самок). В распоряжении мышей всегда была чистая вода и еда в изобилии, специальные гнезда, где можно обустроить себе жилище ― гнезд в загоне хватало для проживания нескольких тысяч мышей. Температура в загоне в среднем составляла около 20 ℃ и была комфортной для мышей. Животные не подвергались никаким влияниям извне и жили в идеальных условиях в свое удовольствие. А дальше началось самое интересное. На первом этапе эксперимента мыши хорошо размножались, вели активный образ жизни, охотно играли. На следующей фазе эксперимента мыши стали есть меньше, перестали наедаться до отвала. На третьей фазе эксперимента, когда в загоне были уже сотни мышей, произошло распределение социальных ролей, стала ярко выраженной иерархия, клановость. Появились так называемые отверженные ― молодые особи, которых другие, взрослые мыши сгоняли в центр загона, не давали им вести нормальный образ жизни, причиняли физический вред. В природе такое, наверное, было бы невозможно, ведь эти мыши-агрессоры просто не дожили бы до старости: их бы съели хищники. Но в загоне Кэлхуна хищников не было, и взрослые мыши начали попросту издеваться над молодняком. Образовались две большие группировки: самцы-одиночки и самки-одиночки. При этом самки-одиночки отказывались спариваться <с менее статусными многочисленными молодыми самцами и с оставшимися старыми статусными> и отвергали ухаживания самцов. У мышей стал проявляться тотальный индивидуализм, мыши не стремились создать семью. На последней, четвертой стадии мышиная популяция стала сокращаться. Появились самцы, которых сам Кэлхун назвал «красивыми» (англ. beautiful ones), из-за отсутствия ран и рубцов. <В оригинале: They never engaged in sexual approaches toward females, and they never engaged in fighting, and so they had no wound or scar tissue. Thus their pelage remained in excellent condition. - Дословный перевод: Они никогда не прибегали к сексуальным подходам к самкам, и они никогда не участвовали в боях, и поэтому у них не было ран или рубцовой ткани. Таким образом, их шерсть сохранилась в отличном состоянии.> Эти мыши не вступали в борьбу за самок и территорию, не проявляли активности к размножению и только питались, спали и чистили шёрстку. У мышей стали проявляться различные формы девиантного поведения, вспышки агрессии. Самки стали проявлять агрессию, защищать себя сами, стали умерщвлять своих детенышей, а затем окончательно отказались размножаться. На пике эксперимента в загоне одновременно проживало чуть более двух тыс. мышей. Еды и гнезд было достаточно для дальнейшего роста популяции, но через четыре года после начала эксперимента Кэлхун остановил свой опыт, потому что в загоне осталось чуть более сотни мышей, и все они уже вышли из репродуктивного возраста. По итогам эксперимента Кэлхун пришел к выводу, что достижение определенной плотности населения и заполнение социальных ролей в популяции приводит к распаду общества" https://physicsoflife.pl/dict/pic/calhoun/calhoun.. https://scientificrussia.ru/articles/utopiya-dlya-mys.. https://ru.wikipedia.org/wiki/Кэлхун,_Джон_(этолог)
    • gudstartup
      @Koels вот в чем дело пока ds609 это предупреждение поэтому F может и не появится если sv601 это значит ошибка. возможно при нагреве радиатора серво определяет это как предупреждение или ваш вентилятор крутиться медленнее чем оригинальный и серва думает что он встал хотяпри этом обычно на экране в строке состояния FAN.мигает больше у меня вариантов нет....  
    • ДОБРЯК
      Решите любым алгоритмом. Тогда будет конструктивный разговор. :=)
×
×
  • Создать...