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

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


алексей556

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

В 23.10.2017 в 21:36, Kir95 сказал:

Напишите MsgBox "Версия-" + Rev

результат тот же - пустое значение. sw2012. код взят из предыдущего поста, как было написано. Почему то не хочет вычислять значение из переменной revision (ни в свойствах, ни в макросе):Screenshot_8.thumb.png.2c5705b9ecf810e3362c7e9659b08bae.png

Screenshot_9.png.0dbb087f0d4d84a315c76f2e7d6b51ca.png

 

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


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

результат тот же - пустое значение. sw2012. код взят из предыдущего поста, как было написано. Почему то не хочет вычислять значение из переменной revision (ни в свойствах, ни в макросе):

Может во втором виде у вас другая модель (без ревизии) или второй вид пустой (без моделей)?

Ведь предложенный макрос выбирает первый вид, а потом выбирает второй:

    Set swView = swDraw.GetFirstView
    Set swView = swView.GetNextView

Может вторую строчку исключить и остановиться только:

    Set swView = swDraw.GetFirstView

Ссылка на сообщение
Поделиться на других сайтах
В 20.10.2017 в 15:22, Kelny сказал:

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

сначала была ошибка что swNote не определено, добавил так: Dim swNote As SldWorks.ModelDoc2 

потом ошибка: run-time error 424 Object required на строке Set swNote = ModelDoc2.InsertNote("$PRPSHEET:" & Chr(34) & "Revision")

у меня sw2012.

20 минут назад, Kelny сказал:

Может вторую строчку исключить

если исключить - ошибка

Screenshot_10.png.2e0724d81c871d84d8e8877d35984d68.png

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

если исключить - ошибка

Может активирован режим:

' Включаем проверку переменных VBA
Option Explicit

и требуется объявить swCustProp или убрать проверку.

 

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

сначала была ошибка что swNote не определено, добавил так: Dim swNote As SldWorks.ModelDoc2 

потом ошибка: run-time error 424 Object required на строке Set swNote = ModelDoc2.InsertNote("$PRPSHEET:" & Chr(34) & "Revision")

у меня sw2012.

Вы чего-то всё мешаете в одну кучу, я приводил свой метод считывания значения с заметки. Данный метод сработал?

 

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

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

Вы чего-то всё мешаете в одну кучу

это два разных теста/макроса (пробую и так и так) - пока оба не работают.

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

Может вторую строчку исключить и остановиться только:

FirstView у солида - это лист. Исключив вторую строчку вы будете брать значения с null вида.

Ссылка на сообщение
Поделиться на других сайтах
В 19.10.2017 в 08:06, streamdown сказал:

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

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

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

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

1) текущий чертеж детали/сборки
2) в имя файла.
3) ничего
4) себе.

Еще вопросы будут или предложите решение?

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

Еще вопросы будут

На, выполняй поставленную себе задачу по написанию тебе макроса))

(основа с поста выше)

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

 

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 confName 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
    confName = swView.ReferencedConfiguration
    Set swCustProp = swModel.Extension.CustomPropertyManager(confName)
        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)

If Trim(Rev & vbNullString) = vbNullString Then
    MsgBox "Нет версии! Сохранение не произойдёт"
    Exit Sub
End If

NewFilePath_dwg = sPath & sName & " - Версия " & Rev & ".slddrw"

Part.SaveAs2 NewFilePath_dwg, 0, True, False

MsgBox "Готово"

End Sub

 

 

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

confName = swView.ReferencedConfiguration
    Set swCustProp = swModel.Extension.CustomPropertyManager(confName)

Спасибо за уточнение, теперь работает! По моему вопросу я ожидал более скромный ответ, а не целиком код :) Что то типа:

Dim swCustProp As CustomPropertyManager

Dim Rev As String

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

    Set swDraw = swApp.ActiveDoc
    Set swView = swDraw.GetFirstView
    Set swView = swView.GetNextView
    Set swModel = swView.ReferencedDocument
    confName = swView.ReferencedConfiguration
    Set swCustProp = swModel.Extension.CustomPropertyManager(confName)
        swCustProp.Get2 "Revision", 30, Rev  ' значение переменной Revision, описанной в 3д модели

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

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

Да... тотал :bleh:

Ссылка на сообщение
Поделиться на других сайтах
В 04.11.2017 в 19:25, Maik812 сказал:

А вообще зачем нужно видеть ревизию в имени файла?

Затем, что некоторые отечественные системы менеджмента файлов. при открытии одноименных файлов от разных "версий" объектов, пишут "файл с таким именем уже открыт. перечитать?" и закрывают файл.

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

Затем, что некоторые отечественные системы менеджмента файлов. 

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

 

Revision  показывает и сортирует, также вводится в фаил . но все до 2015 версии Солида. Не кто не хочет плагин написать с АПИ.

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

Не кто не хочет плагин написать с АПИ.

За то время что вы рассказываете что вам ни кто ни чего не пишет уже бы сами ни один раз освоили и писали бы в своё удовольствие всё что вам хочется...

Ссылка на сообщение
Поделиться на других сайтах
  • 2 месяца спустя...

Доброго времени суток. Требуется макросом записать значения двух переменных в третью в формате "Переменная1"_"Переменная2". Сторонняя программа берет значение из колонки Значение/текстовое выражение, а не из вычисленное значение. Ткните пожалуйста в пример кода...

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

макросом записать значения двух переменных в третью в формате "Переменная1"_"Переменная2". Сторонняя программа берет значение

а без макроса это как выглядит, в смысле переменные откуда берутся и где будут, в уравнениях или свойствах файла?

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

Переменные будут в свойствах файла.

При передачи развертки в CNCKad (dxf и dft) необходимо в название файла вставить информацию о материале (сортамент и толщина). Эти два параметра вносятся из списка вырезов и панели свойств. Вставить в название файла можно только одну переменную и она берется из колонки Значение/текстовое выражение  - поэтому необходим макрос для записи значения.

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

Этот вариант не подходит.. Нужно сразу значение прописать без вычисления

Снимок.JPG

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

необходимо в название файла вставить информацию о материале (сортамент и толщина).

У вас свойство CNCKad прописано заранее? И вы в свойствах Конфигурации вручную или макросом заполняете значение Сортамент и Толщина, получаете значение  CNCKad, затем хотите запустить макрос, который бы активный файл "Деталь1_00" сохранил под именем "Деталь1_00 Оцинковка-2мм" в папку детали? То есть "Имя файла+CNCKad"? Версия солида какая?

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

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

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

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

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

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

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

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

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

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

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




  • Сообщения

    • Viktor2004
      Импортозамещение  
    • vad0000
      Нет, просто отключаете, и забываете о ней   Не надо ничего делать   Откуда приходит сигнал 24 вольта на 7 вход сервоусилителя? Фото другой страницы схемы
    • maxx2000
    • vladimir.songin
      То есть отключаю аналоговую обратную связь от аналогового входа, и подключаю вместо энкодера? Так не делал но сомнения у меня: Вход энкодера может  быть 12 или 5 вольт. У нас 12. Два пина питание, два пина Каналы A B соответственно, один пин REF (непонятно что он означает и как работает). Остальные соеденены вместе. На какие из них подавать аналаговый вход обратной связи дефлектора.  сигналы от энкодера приходят, проверял осцилографом на самом разьёме непосредственно на входе DM02, и некое значение уже могло бы отобразиться в поле энкодера при отключенном аналаговом входе.  Если отключить аналоговый вход, то видим единичку в обоих полях, но уже писал об этом.  
    • Алексей 1977
      Кто знает подскажите как отключить этот ненужный набор букв и символов в готовой УП? Я так думаю надо редактировать постпроцессор? Заранее спасибо ( Общая длина: 130.0) ( Заготовка:) ( MIN X: -10.970) ( MIN Y: -10.970) ( MIN Z: -6.500) ( MAX X: 10.970) ( MAX Y: 10.970) ( MAX Z: 0.000) ( COORDINATE SYSTEM: Глобальная СК) ( Кончик инструмента:) (   X: -0.000) (   Y: 0.000) (   Z: 10.000) ( Рекомендованная длина: 50.000) ( Количество кромок: 4) ( Инструмент:   Концевая фреза) ( DIAMETER: 10.000) ( Безопасность:) ( Рабочие ходы инструмента: Безопасная БЕЗ зарезов) ( Подводы инструмента: Безопасная БЕЗ зарезов) ( Переходы инструмента: Безопасная БЕЗ зарезов) ( Рабочие ходы патрона: Столкновения НЕ проверялись) ( Подводы патрона: Столкновения НЕ проверялись) ( Переходы патрона: Столкновения НЕ проверялись) ( Траектория: Шаблон) ( STEPOVER: 5.000) ( ДОПУСК:0.100) ( THICKNESS:0.000) ( Статистика:) ( LENGTH: 95.318)( LIFTS: ( TIME: 0/00/05) 1) G0X0Y0 G43Z10.H13 X4.75Y-8.227 Z5. G1Z0F500 X9.5Y-5.485F1000 Y5.485 X0Y10.97 X-9.5Y5.485 Y-5.485 X0Y-10.97 X4.75Y-8.227 G0Z10.
    • gudstartup
      считывание происходит при помощи вх\вых сигналов контроллера plc 
    • gudstartup
      @Maks Horhe так все таки скиньте бэкап эмулируем ваше чпу в cncguide и посмотрим куда поедет?  можете снять видео с фиксацией координатных позиций после каждого кадра. Выложу вашу программу пусть программисты посмотрят все ли в ней ок. %O0002 G40 G17 G94 G90 G49 G80 N1 G91 G28 Z0.0 N2 G91 G28 X0.0 Y0.0 N3 G91 G28 B0.0 C0.0 N4 M03 S200 N5 G90 G0 G53 B0.0 C0.0 N6 G54 N7 X0.0 Y0.0 N8 G90 G43 H01 N9 G90 G0 X0.0 Y0.0 N10 G90 G0 Z200.0 N11 G01 Z10.0 F1500. N12 M00 N13 G00 Z200.0 N14 G40 G49 G69 N15 G00 G53 Z0.0 N16 G00 G54 B0.0 C0.0 N17 G68.2 X0.0 Y0.0 Z0.0 1135. J39.2044 K-129.2315 N18 G53.1 N19 G01 X0.0 Y0.0 F1500 N20 G90 G43 H01 N21 G90 G01 X0.0 Y0.0 F1500 N22 G90 G01 Z200. F1500 N24 M00 N25 G00 Z200. N26 G40 G49 G69 N27 G91 G28 Z0.0 N28 G28 X0.0 Y0.0 N29 G91 G28 B0.0 C0.0 N30 M5 N31 M30
    • gudstartup
      @karlf 530 считывает ключ по специальному протоколу при помощи plc и получает его серийный номер а из него определяет возможные режимы доступа. там нет драйвера а есть plc модуль или несколько эти модули написаны на питоне  надпись smartkey исчезает с экрана при запуске чпу??
    • ДОБРЯК
      Для того, чтобы получить правильные высшие) формы при виртуальном эксперименте, нужно сделать грамотную КЭ модель. От разговора на эту тему вы постоянно уклоняетесь.  То нет компьютера под рукой, сделать простейший тест, то теряете интерес. :=) Сходимости энергии деформации при расчетах статики, недостаточно для точного определения высших собственных форм и частот.  Для того, чтобы грамотно использовать метод конечных элементов, нужно сделать много-много тестов в статике, динамике и ... Одной кнопки и двух конечных элементов в 3Д программе недостаточно для определения высших собственных форм...  У вас в качестве инструмента всего два конечных элемента, шести узловая несовместная оболочка Тимошенко и десяти узловой тетраэдр. И еще контакты при решении задачи на собственные числа. Вам ли говорить про правильность определения высших собственных форм для сложных изделий... :=)    
    • vad0000
      Покажите схему с разрешением на движение
×
×
  • Создать...