Ik weet niets van macro's en ik zou graag willen weten of het mogelijk is om een DXF-exportmacro te maken die alle vellen van een tekening in aparte bestanden exporteert met behoud van de namen van de vellen.
Na het zoeken op het forum vond ik dit onderwerp met de macro bijgevoegd, dat is wat ik in principe zoek, alleen doet het PDF's en niet DXF's:
Kan een goede ziel van het forum deze macro voor mij wijzigen om de PDF te vervangen door de DXF. Behoudt de macro de SolidWorks-opties voor "opslaan als" die ik gebruik wanneer ik dit handmatig doe, zoals het gebruik van een projectiebestand?
Ik weet niet zeker of ik het vorige bericht begrijp.
Is dit de PDF-macro gedaan en de DXF-macro zou moeten doen die we moeten begrijpen?
Ik heb de macro niet geopend, maar als er gewoon een wijziging van de bestandsextensie op de hele code was, wordt deze logischerwijs alleen in een ander formaat opgeslagen.
De macro "pdf_page_par_page.swp" maakt 1 bestand per tekenblad aan en bevat in de PDF-bestandsnaam de naam van het tekeningbestand + de naam van het blad
Als het tekeningbestand bijvoorbeeld "TOTO" heet en 2 vellen heeft, "PLAN" en "Rep A", doet de PDF-macro het volgende:
1 "TOTO_PLAN" bestand met alleen het "PLAN" blad
1 "TOTO_Rep A" bestand met alleen het "Rep A" blad
Van mijn kant ben ik ingesteld op "Exporteer alle bladen in een bestand" en ik heb geen probleem.
Alleen als de instelling "Exporteer alle bladen in afzonderlijke bestanden" is, genereert de export 4 bestanden.
Wat me ook is opgevallen, is dat je de wijziging van instellingen twee keer moet forceren om er correct rekening mee te houden (waarschijnlijk SW2020-bug).
Normaal gesproken voldoet de onderstaande code aan de behoefte
Option Explicit
Dim swApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swDraw As SldWorks.DrawingDoc
Dim sPathname As String
Dim vSheetName As Variant
Dim nErrors As Long
Dim nWarnings As Long
Dim i As Long
Dim bRet As Boolean
Dim lParam As Long
Sub main()
Set swApp = Application.SldWorks
Set swModel = swApp.ActiveDoc
Set swDraw = swModel
lParam = swApp.GetUserPreferenceIntegerValue(swDxfMultiSheetOption)
'Changement paramétrage export dxf si différent de feuille active
If lParam <> 0 Then
bRet = swApp.SetUserPreferenceIntegerValue(swUserPreferenceIntegerValue_e.swDxfMultiSheetOption, swDxfMultisheet_e.swDxfActiveSheetOnly)
End If
sPathname = swModel.GetPathName
sPathname = Left(sPathname, Len(sPathname) - 7)
vSheetName = swDraw.GetSheetNames
For i = 0 To UBound(vSheetName)
bRet = swDraw.ActivateSheet(vSheetName(i))
bRet = swModel.SaveAs4(sPathname & "_" & vSheetName(i) & ".dxf", swSaveAsCurrentVersion, swSaveAsOptions_Silent, nErrors, nWarnings)
Next i
' Retour à la Feuille 1
bRet = swDraw.ActivateSheet(vSheetName(0))
' Remise en place du paramétrage initial
bRet = swApp.SetUserPreferenceIntegerValue(swUserPreferenceIntegerValue_e.swDxfMultiSheetOption, lParam)
End Sub