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

Сделай свою работу в Solidworks эффективнее


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

1 час назад, ГЕЛА сказал:

Извиняюсь что не со всем в ту тему , но кто подскажет - при попытке использовать шераховатость из поста выше , выходит так - в знаке вместо цифр пустота.

Сбой в кодировке файла (вероятно после добавления символов сохранили в неподходящую кодировку):

https://cccp3d.ru/topic/32914-помощь-новичку-solidworks/?do=findComment&comment=1317774

 

3 часа назад, tompsongun сказал:

может кому пригодится в gtol.sym добавить можно такие значки

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

 

Возможно лучше воспользоваться БЛОКом, тогда он будет прикреплён к каждому файлу где применён.

Или использовать штатный инструмент ШЕРОХОВАТОСТИ добавенный в ЗАМЕТКУ - в этом случае будет подчёркиваться весь знак. Если использовать ЗНАК ШЕРОХОВАТОСТИ без заметки, тогда подчёркивается только галка, что не соответствует ГОСТу.

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


Появилась необходимость выбирать детали в сборке по цвету.  Есть куча деталей (разных), некоторые из них сделаны по одному принципу. Раскрасил все однотипные в определенные цвета, теперь хотелось бы как-то по цвету их выбирать. Никто не встречал решения?

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

конечно, макросов много было с сохранением в ,например, пдф.

тут поддаработал - проверка на существование файла и если он есть, то окошко на сохранение с новым именем. может пригодится.

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

Dim swApp As Object

Public swModel As Object
Dim boolstatus As Boolean
Dim Path            As String
Public PathNoExtension As String
Dim NewFilePath     As String
Dim sFileName       As String
Dim nErrors         As Long
Dim nWarnings       As Long
Dim longstatus As Long, longwarnings As Long
Dim FSO
Public CharPos     As Long
Public ИмяМодели As String
Public ДлинаИмени As Integer
Public vyhod As Integer


Sub main()

Set swApp = _
Application.SldWorks
vyhod = 0
    
Set swModel = swApp.ActiveDoc

Set FSO = CreateObject("Scripting.FileSystemObject")

FilePath = swModel.GetPathName
PathSize = Strings.Len(FilePath)
PathNoExtension = Strings.Left(FilePath, PathSize - 6)

    CharPos = InStrRev(FilePath, "\")
    ИмяМодели = Right$(FilePath, (Len(FilePath) - CharPos))
    ИмяМодели = Left$(ИмяМодели, Len(ИмяМодели) - 7)
    ДлинаИмени = Len(ИмяМодели)


proverka:

NewFilePath = PathNoExtension & "PDF"
If FSO.FileExists(NewFilePath) = True Then
    If MsgBox("Файл с таким именем" & vbNewLine & PathNoExtension & vbNewLine & _
            "уже существует! ЗАМЕНИТЬ его?" & vbNewLine & "(кнопка *Нет* - диалог переименования)", vbYesNo + vbExclamation, "SaveAsPDF") = vbYes Then
        swModel.SaveAs3 NewFilePath, 0, 0
    Else
    UserForm1.Show
        If vyhod = 1 Then Exit Sub
    GoTo proverka
    End If
 End If
 
swModel.SaveAs3 NewFilePath, 0, 0
   Set swModel = Nothing
 End Sub

 

--------------------------------- код формы-------------------------------

Option Explicit

Private Sub UserForm_Initialize()

UserForm1.TextBox1.Text = ИмяМодели

End Sub

Public Sub кнОтмена_Click()
Unload UserForm1:    Set swModel = Nothing
vyhod = 1
Exit Sub
End Sub

Public Sub кнГотово_Click()

PathNoExtension = Strings.Left(PathNoExtension, Strings.Len(PathNoExtension) - ДлинаИмени - 1)

ИмяМодели = UserForm1.TextBox1.Text

PathNoExtension = PathNoExtension & ИмяМодели & "."
Unload UserForm1

End Sub

 

 

изображение.pngизображение.png

SaveToSTL.zip

SaveToJPGhand.zip

SaveToPDFHand.zip

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

конечно, макросов много было с сохранением в ,например, пдф.

тут поддаработал - проверка на существование файла и если он есть, то окошко на сохранение с новым именем. может пригодится.

  Показать содержимое

Dim swApp As Object

Public swModel As Object
Dim boolstatus As Boolean
Dim Path            As String
Public PathNoExtension As String
Dim NewFilePath     As String
Dim sFileName       As String
Dim nErrors         As Long
Dim nWarnings       As Long
Dim longstatus As Long, longwarnings As Long
Dim FSO
Public CharPos     As Long
Public ИмяМодели As String
Public ДлинаИмени As Integer
Public vyhod As Integer


Sub main()

Set swApp = _
Application.SldWorks
vyhod = 0
    
Set swModel = swApp.ActiveDoc

Set FSO = CreateObject("Scripting.FileSystemObject")

FilePath = swModel.GetPathName
PathSize = Strings.Len(FilePath)
PathNoExtension = Strings.Left(FilePath, PathSize - 6)

    CharPos = InStrRev(FilePath, "\")
    ИмяМодели = Right$(FilePath, (Len(FilePath) - CharPos))
    ИмяМодели = Left$(ИмяМодели, Len(ИмяМодели) - 7)
    ДлинаИмени = Len(ИмяМодели)


proverka:

NewFilePath = PathNoExtension & "PDF"
If FSO.FileExists(NewFilePath) = True Then
    If MsgBox("Файл с таким именем" & vbNewLine & PathNoExtension & vbNewLine & _
            "уже существует! ЗАМЕНИТЬ его?" & vbNewLine & "(кнопка *Нет* - диалог переименования)", vbYesNo + vbExclamation, "SaveAsPDF") = vbYes Then
        swModel.SaveAs3 NewFilePath, 0, 0
    Else
    UserForm1.Show
        If vyhod = 1 Then Exit Sub
    GoTo proverka
    End If
 End If
 
swModel.SaveAs3 NewFilePath, 0, 0
   Set swModel = Nothing
 End Sub

 

--------------------------------- код формы-------------------------------

Option Explicit

Private Sub UserForm_Initialize()

UserForm1.TextBox1.Text = ИмяМодели

End Sub

Public Sub кнОтмена_Click()
Unload UserForm1:    Set swModel = Nothing
vyhod = 1
Exit Sub
End Sub

Public Sub кнГотово_Click()

PathNoExtension = Strings.Left(PathNoExtension, Strings.Len(PathNoExtension) - ДлинаИмени - 1)

ИмяМодели = UserForm1.TextBox1.Text

PathNoExtension = PathNoExtension & ИмяМодели & "."
Unload UserForm1

End Sub

 

 

изображение.pngизображение.png

SaveToSTL.zip 16 \u041a\u0431 · 0 скачиваний

SaveToJPGhand.zip 13 \u041a\u0431 · 0 скачиваний

SaveToPDFHand.zip 12 \u041a\u0431 · 0 скачиваний

два варианта, заменить или создать с новым именем? А как же отмена?)

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

отмена= ответить "нет", появится второе окошко и там "отмена" кнопка  ))))))))))

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

отмена= ответить "нет", появится второе окошко и там "отмена" кнопка  ))))))))))

автор конечно хозяин, но мне кажется логичнее "да, нет, отмена" на первом окне

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

автор конечно хозяин, но мне кажется логичнее "да, нет, отмена" на первом окне

Кроме этого второе окно лишнее и неплохо бы обойтись одним со всеми вариантами.

Так понимаю, автор просто ещё не разобрался как добавить кнопок в MsgBox:

https://docs.microsoft.com/ru-ru/office/vba/language/reference/user-interface-help/msgbox-function

 

37 минут назад, tompsongun сказал:

тут поддаработал - проверка на существование файла и если он есть, то окошко на сохранение с новым именем. может пригодится.

Судя по скриншоту второе окошко создано вручную и вполне можно было бы добавить несколько кнопок с вариантами не вызывая предватиельно MsgBox.

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

 

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

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

Привет всем. Долго искал макрос для SolidWorks, много похожего, но конкретного не нашел.  Может кто подскажет или покажет. Суть в чем:  есть необходимость менять обозначение и наименование из имени файла, или только обозначение. Формат имени файла таков: АБВГД.000.000.000 - Втулка осевая. Как разделить на 2 части, чтобы до пробела улетала в обозначение, а вторая часть в наименование?

И еще вопрос, есть ли какой макрос сохранения спецификации в excel? Шаблоны спецификации и форматки листа нестандартные, созданные, как я понимаю "от руки". Заранее благадарю 

 

Ссылка на сообщение
Поделиться на других сайтах
Вадим Митрофанович
18 часов назад, Akimyshka сказал:

Привет всем. Долго искал макрос для SolidWorks, много похожего, но конкретного не нашел.  Может кто подскажет или покажет. Суть в чем:  есть необходимость менять обозначение и наименование из имени файла, или только обозначение. Формат имени файла таков: АБВГД.000.000.000 - Втулка осевая. Как разделить на 2 части, чтобы до пробела улетала в обозначение, а вторая часть в наименование?

И еще вопрос, есть ли какой макрос сохранения спецификации в excel? Шаблоны спецификации и форматки листа нестандартные, созданные, как я понимаю "от руки". Заранее благадарю 

 

А в чем у вас проблема? Пишите АБВГ.00.00.000 Втулка После номера-перед втулкой пробел. Тогда Солид в свойствах сам делит на Обозначение и Наименование. Это давно известный макрос MProp для внесения свойств. Если вам надо поменять номер и название-меняйте (с таким же пробелом) и обновите свойства в макросе. В спецификацию так же автоматом оно вставляет.

7 минут назад, Вадим Митрофанович сказал:

А в чем у вас проблема? Пишите АБВГ.00.00.000 Втулка После номера-перед втулкой пробел. Тогда Солид в свойствах сам делит на Обозначение и Наименование. Это давно известный макрос MProp для внесения свойств. Если вам надо поменять номер и название-меняйте (с таким же пробелом) и обновите свойства в макросе. В спецификацию так же автоматом оно вставляет.

Кстати набор готовых макросов SWPlus включает в себя и спец и многое другое

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

И еще вопрос, есть ли какой макрос сохранения спецификации в excel?

SW сам свою спецификацию сохраняет в файл MS Excel

Ссылка на сообщение
Поделиться на других сайтах
13.08.2022 в 14:37, Вадим Митрофанович сказал:

А в чем у вас проблема? Пишите АБВГ.00.00.000 Втулка После номера-перед втулкой пробел. Тогда Солид в свойствах сам делит на Обозначение и Наименование. Это давно известный макрос MProp для внесения свойств. Если вам надо поменять номер и название-меняйте (с таким же пробелом) и обновите свойства в макросе. В спецификацию так же автоматом оно вставляет.

Кстати набор готовых макросов SWPlus включает в себя и спец и многое другое

Это все понятно, суть в том, что нужно чтобы именно из имени файла, а не из свойств. Аналогично $PRP:"SW-File Name, но только 1 часть, до пробела или задаваемого символа. Мне где-то попадалось что-то подобное, но не могу вспомнить 

13.08.2022 в 16:55, brigval сказал:

SW сам свою спецификацию сохраняет в файл MS Excel

Я имел ввиду, что-то наподобие SaveAsPDF, только для спецификации и в Excel. Пробовал макрос, который сохраняет сначала в .csv и потом конвертирует его в .xls, но в данном случае спецификация получается некорректная. Возможно ли сразу в .xls  

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

интересен именно макрос для этого 

Писал коллега по работе. Для сохранения нужно встать на лист со спецификацией. Вроде, давно не пользовался. :smile:

Экспорт специфиикации в Эксель.bmp Экспорт специфиикации в Эксель.swp

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

Писал коллега по работе. Для сохранения нужно встать на лист со спецификацией. Вроде, давно не пользовался. :smile:

Экспорт специфиикации в Эксель.bmp 568 \u0411 · 3 скачивания Экспорт специфиикации в Эксель.swp 60 \u041a\u0431 · 1 скачивание

Спасибо большое!! А не подскажете, как сделать, чтобы шрифт не слетал при работе макроса?

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

А не подскажете, как сделать, чтобы шрифт не слетал при работе макроса?

Не подскажу, я в этом не разбираюсь. Могу только посоветовать в экселе сделать макрос для замены шрифта на нужный.  :smile:

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

Не подскажу, я в этом не разбираюсь. Могу только посоветовать в экселе сделать макрос для замены шрифта на нужный.  :smile:

Ладно, спасибо) попробую сам поковырять. Осталось, чтобы ещё кто помог с именем файла 

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

Ладно, спасибо) попробую сам поковырять. Осталось, чтобы ещё кто помог с именем файла 

Рекомендую программку Брасол, которая умеет контролировать совпадение номеров позиций в спецификации Excel и сборочном чертеже SW.

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

Рекомендую программку Брасол, которая умеет контролировать совпадение номеров позиций в спецификации Excel и сборочном чертеже SW.

Хорошо, посмотрю

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

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

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

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

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

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

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

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

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

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

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



  • Сообщения

    • Snake 60
      Скорее всего исправляли в конкретной сборке, для конкретных тел. Насколько я помню, надо в самом эскизе профиля заполнить свойство Description
    • Snake 60
      Делаете дырку в свае - вставляете в нее трубу и 2 человеко-силы крутят сваю ) Дёшево и сердито и не нужен никакой планетарный редуктор ))
    • gudstartup
      вы всегда ищите свой путь или будете делать то что вам советуют? с самого начала прежде чем приступать к экспериментам вам нужно было вынуть носитель и сделать образ. diskcopy делает копию гибкого диска на другой а вам надо сделать образ жесткого диска или карты памяти. делайте как советует @Viktor2004 иначе еще чего нибудь сломаете или вам станок не нужен и вы его приобрели для экспериментов ? вот а печатной машинке из прошлого нельзя а вот на синумерике можно - удивительные вещи в настоящем происходят!! на 100 % уверен что там не модуль а либо писимиси ай либо жд @mircomax81 хотите работать в дос почитайте помощь по командам 
    • PuKoLLleT
      Доброго дня всем. Поделитесь опытом,раньше такое не доводилось делать. На торце фланца нужно сделать  восемь отверстий ф17H7 на токарно-фрезерном станке с осью Y ,имеется ManualGuide.В моем понимании нужно просверлить,а затем торцевой фрезой расточить нужный диаметр.Получится такой фокус,или надо разверткой доводить нужный размер?  Стойка Fanuc 0i-Tf.
    • Snake 60
      Всё верно, я даже русификатор делал для него (ушло на это где-то около года). Хороший софт был, я всех знакомых на него подсадил в свое время :) У меня даже где-то образ на виртуалке лежит с SW2014+MechSoft, Жаль, что автодеск его поглотил, а не DS :( А по сути вопроса, проектировал двухступенчатый планетарный редуктор в свое время. Что было нужно: Справочник по планетаркам (автора не помню, если надо поищу), из софта MathCAD + GearTeq (софтина идет вместе с GearTrax, только рассчитывает и моделирует несколько зацеплений согласно выбранной схеме, в том числе планетарки) Ой и ошибаетесь. Звездочки - не равно зубчатые колеса в планетарке) Мы намучились с малой точностью изготовления на эл.эрозии, а Вы лазером ))) Был собран опытный образец редуктора с незакаленными деталями, чисто проверить геометрию, отладить сборку. Так потом начальство этот редуктор сказало испытать в бою, как я не противился)) Помер за пару дней интенсивных нагрузок ))) Материал, термообработка и точности изготовления решают )
    • Snake 60
      @Тихоход  Ещё один вариант - изучать программирование и писать свою программу/макрос. Вот пример конфигуратора двери: https://www.youtube.com/watch?v=wv4HryWQBSk
    • mircomax81
      Посредством Diskcopy можно сделать адекватную копию на флоппи диск?
    • Andrey_kzn
      Да, ведь советовали автору вытащить жёсткий диск и сделать образ. Неужели самому не интересно, как устроен этот старый промкомпьютер? Там может стоять как жёсткий диск, так и CF-карта, или же Disc-on-chip или Disc-on-module.  Как-то очень давно, на подобном промышленном оборудовании (большая печатная машина) я не смог перенести  ПО с родной CF - карты на другую, такого же размера но другой фирмы. Была также станочная оболочка под досом.  Образ я делал Нортон гостом, развернул его на другую CF-карту без проблем. Машина загрузилась нормально и работала ровно 2 дня, на неродной CF-карте,  потом зависла, и отказалась загружаться. Пришлось вызывать сервисника. От него мы узнали, что нельзя просто так взять и заменить карту  - носитель системного ПО, на другую. А полезли мы туда, так как руководство захотело печатать отчёты по работе машины. В станочном ПО такая функция была. Вот только принтер надо было купить у фирмы - производителя этой самой машины. В попытках заставить работать другой принтер мы редактировали файл  AUTOEXEС.BAT, на предмет загрузки драйвера принтера, ничего не получилось, зато перестали открываться некоторые страницы станочного ПО.  Образ у нас был давно снят, и мы развернули его на другую карту памяти. Родную карту я трогать не стал (как чувствовал, что нельзя ). Сервисник восстановил ПО с архивной дискеты на родную карту памяти, и всё заработало. Дискеты с архивами ПО шли вместе с документацией к машине.  Там были дискеты с Досом, станочной оболочкой, параметрами приводов, программой ПЛК. Он же и предупредил нас о предельно аккуратном обращении с родной картой памяти, и посоветовал немедленно сделать образы с архивных дискет, что мы сразу и проделали.. Вот такой сюрприз от машины эпохи Дос.
    • Борман
    • gudstartup
      а ведь все работало...
×
×
  • Создать...