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

Macro_Присвоение для 1 переменной n-значений


Donnii

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

Добрый день, помогите пожалуйста разобрать  и сделать макрос.

Макрос и профиль в 2д ниже. Макрос был скачан и изменен.

1 ошибка я так понимаю в Private Sub UserForm_Activate() - он не должен повторяться

2 курьез это в  Part.ClearSelection2 True
                        Part.DeleteAllRelations

Т.е. каждый раз он удаляет все значения всех переменных, возможно ли обойти это как то при помощи Part.Recordset... или как то иначе

3. стоит ли задавать саму переменную к примеру Dim D As String?

Сам макрос:

 

Dim swApp As Object
Dim Part As Object
Dim boolstatus As Boolean
Dim longstatus As Long, longwarnings As Long

Private Sub ComboBox1_Change()
End Sub

Private Sub ComboBox2_Change()
End Sub

Private Sub ComboBox3_Change()
End Sub

Private Sub CommandButton1_Click()
Set swApp = Application.SldWorks
Set Part = swApp.ActiveDoc
Part.ClearSelection2 True
Part.DeleteAllRelations
Part.AddRelation """D""= " & ComboBox1.Value
End Sub

Private Sub CommandButton2_Click()
Set swApp = Application.SldWorks
Set Part = swApp.ActiveDoc
Part.ClearSelection2 True
Part.DeleteAllRelations
Part.AddRelation """A""= " & ComboBox2.Value
End Sub

Private Sub CommandButton3_Click()
Set swApp = Application.SldWorks
Set Part = swApp.ActiveDoc
Part.ClearSelection2 True
Part.DeleteAllRelations
Part.AddRelation """B""= " & ComboBox3.Value
End Sub

Private Sub Label1_Click()
End Sub

Private Sub Label2_Click()
End Sub

Private Sub Label3_Click()
End Sub
'1=D
Private Sub UserForm_Initialize()
Me!ComboBox1.AddItem 253.2
Me!ComboBox1.AddItem 304
Me!ComboBox1.AddItem 329.4
End Sub

'2=A
Private Sub UserForm_Activate()
Me!ComboBox2.AddItem 76
Me!ComboBox2.AddItem 89
Me!ComboBox2.AddItem 101.5
Me!ComboBox2.AddItem 114.5
Me!ComboBox2.AddItem 127
End Sub

'3= B
Private Sub UserForm_Activate()
Me!ComboBox3.AddItem 10
Me!ComboBox3.AddItem 11
Me!ComboBox3.AddItem 12
End Sub

 

Заранее спасибо!

 

 

macric.rar

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


1 ошибка я так понимаю в Private Sub UserForm_Activate() - он не должен повторяться

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

 

2 курьез это в Part.ClearSelection2 True

Это снимает все выделения.

 

Part.DeleteAllRelations Т.е. каждый раз он удаляет все значения всех переменных, возможно ли обойти это как то при помощи Part.Recordset... или как то иначе

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

Если требуется удаление некоторых, то вероятно использовать DeleteRelation из SketchRelationManager.

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

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

 

Это снимает все выделения.

 

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

Если требуется удаление некоторых, то вероятно использовать DeleteRelation из SketchRelationManager.

Спасибо, на счет 1 пункта, исправил..

На счет второго c DeleteRelation нужна помощь в верху я  добавил:

 

Dim RelMgr As SketchRelationManager

Dim mySketch As Sketch

 

Private Sub CommandButton1_Click()

Set swApp = Application.SldWorks

'ниже

Set Part = swApp.ActiveDoc

Part.ClearSelection2 True

Set RelMgr = mySketch.RelationManager

RelMgr.DeleteRelation """D""= "

Part.AddRelation """D""= " & ComboBox1.Value

End Sub

Ссылка на сообщение
Поделиться на других сайтах
На счет второго c DeleteRelation нужна помощь
Может примеры в справке глянуть? http://help.solidworks.com/SearchEx.aspx?q=SketchRelation+Example&sort=&version=2010〈=english∏=api
Ссылка на сообщение
Поделиться на других сайтах
  • 2 недели спустя...
Как добавить
 для полноты понимания, я б всё же указывал ссылки на справку на интерфейсы, методы, свойства. Есть много разных мест, где есть Remark, который обязателен к прочтению перед применением.
Ссылка на сообщение
Поделиться на других сайтах

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

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

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

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

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

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

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

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

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

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




  • Сообщения

    • alek77
      Не отработал на нарисованном прямоугольнике: Начальный макрос такие вещи отрабатывает:   SW17 у меня   И еще. И для чертежа с модели тоже не отработал: Хотя я никакими галочками "измененное значение" не пользуюсь, и не знаю где они находятся. Я тупо меняю размер в свойствах: Старый макрос при этом прекрасно все видит и раскрашивает такие размеры. В чем разница не вникал. Просто потестил. Сам я так размеры никогда не меняю, это вредно. А за другими проверить очень даже полезно бывает.  
    • Горыныч
      Не занимайтесь ерундой. В Китае б/у оборудование ОЧЕНЬ ликвидно, а потому дорого. Ну и в 99%случаев уже ушатано почти в ноль. 
    • Guhl
      Кто-нибудь может подсказать сайт, где продаются б/у станки в Китае?
    • gudstartup
      если не повезет то вобразе исправляйте user/system/etc/basesys.ini
    • andref
      @gudstartup  ну если есть PCU50  то все гораздо проще: подключаем к нему мышь , клаву и монитор, загружаемся в Windows и выставляем там  нужный IP (надеюсь что он известен). А вот если 840Dsl без PCU50 , то да... Хотя может просто сетевые разъемы  перепутали  
    • Kate KAUS
      Инжиниринговая компания, специализирующаяся на проектировании морских портов и терминалов приглашает в команду Ведущего/главного инженера-проектировщика ПОС. Чем предстоит заниматься: Разработка разделов проектной документации ПОС согласно ПП№87; Анализ проектной и исходно-разрешительной документации, используемой в качестве данных для составления раздела ПОС Составление ведомостей объемов работ разделов ПОС; Выдача заданий и исходных данных для смежных отделов; Обеспечение увязки принятых решений с проектными решениями других разделов (частей) проекта; Принятие основных технических решений, их обоснование, согласование и защита в органах экспертизы. Разработка основных технических решений на период строительства объектов (ППР, ОПР, строительные решения); Обеспечение соответствия разрабатываемой документации стандартам, техническим условиям, заданию на проектирование.   Требования: Высшее профильное образование (строительное); Опыт не менее 3 лет по специализации ПОС, ППР; Знание требований, предъявляемых к оформлению проектной документации; Умение качественно и в срок выполнять поставленные задачи; Опыт работ на строительных площадках приветствуется; Опыт прохождения согласований проектной документации; Знание ПК на уровне уверенного пользователя: (AutoCAD, Adobe Acrobat PRO, MS Office : Word, Excel, выполнение расчетов в программах).   Мы предлагаем: Трудоустройство согласно ТК РФ Пятидневную рабочую неделю с 9:00 до 18:00 Все социальные гарантии, ДМС Полностью официальную заработную плату, уровень готовы обсуждать с успешным кандидатом Динамично развивающаяся компания, комфортный офис   г. СПб м. Василеостровская, зп от 100 000-140 000р.   Контакты: eksmirnova@kaus-group.ru ТГ @Kate_Kaus  
    • Maks Horhe
      Все ок, работает. Спасибо, только пересчитывает подачи, как отключить пересчет, работать с постоянной подачей? Есть аналог cftcp Siemens? Или надо лезть в параметры?
    • Anat2015
      Боюсь, что не смогу вам помочь, тему прочитал. Я давно уже на административной работе, технические нюансы не помню. Думаю, вам тут помогут.
    • gudstartup
      придется вам вооружиться access my machine выкачать образ cf и там отредактировать сетевые настройки или если образ есть то залить его для восстановления
    • andref
      на фото у вас не стойка а TCU (Thin Client Unit) Посмотрите в шкафу, вот примерно такой блок есть? PCU50.3
×
×
  • Создать...