Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  SolidWorks
  Makro pdf erstellen mit neuem Namen

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für SOLIDWORKS
  
Bechtle Competence Days | Online
Autor Thema:  Makro pdf erstellen mit neuem Namen (861 / mal gelesen)
mareike29
Mitglied
Technikerin Stahl - & Metallbau

Sehen Sie sich das Profil von mareike29 an!   Senden Sie eine Private Message an mareike29  Schreiben Sie einen Gästebucheintrag für mareike29

Beiträge: 1
Registriert: 23.01.2020

erstellt am: 23. Jan. 2020 10:33    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo,

wir haben ein Makro, das ein ehemaliger Kollege erstellt hat, mit dem wir PDF's auf dem Desktop speichern können.

Der Dateiname der PDF ist gleich der SW-Zeichnung.
Wir würden gerne das Makro dahingegend ändern, dass der Dateiname vorher abgefragt wird und wenn nötig geändert werden kann.

Sub main()


' Das Zielverzeichnis steht in der Registrierung. Falls kein Eintrag vorhanden ist,
' wird abgefragt und in die Registrierung zurückgeschrieben.
Arbeitsverzeichnis = GetSetting("SPI-Dateizwischenspeichern", "Config", "Arbeitsverzeichnis")
If Arbeitsverzeichnis = "" Then
    Arbeitsverzeichnis = InputBox("Bitte Speicherort eingeben!", "Unter eindeutigem Namen speichern", Environ$("USERPROFILE") & "\Desktop\")
    SaveSetting "SPI-Dateizwischenspeichern", "Config", "Arbeitsverzeichnis", Arbeitsverzeichnis
    End If


Set swApp = Application.SldWorks

Set Part = swApp.ActiveDoc
swApp.ActiveDoc.ActiveView.FrameState = 1
swApp.ActiveDoc.ActiveView.FrameState = 1
Part.EditSketch
If Part Is Nothing Then End        ' Abbrechen, wenn gar kein SolidWorks-Dokument geöffnet

AktuellesDokTyp = Part.GetType()    ' Part = 1,  Assy = 2,  Zeichnung = 3


Pos1 = InStrRev(swApp.ActiveDoc.GetPathName, "\")
Pos2 = InStrRev(swApp.ActiveDoc.GetPathName, ".")


If (swApp.ActiveDoc.GetPathName = "") Then          'Abfrage ob Name vergeben wurde
    MsgBox ("Bitte zuerst Zeichnung speichern!")
    Exit Sub
End If

If AktuellesDokTyp = 3 Then saveFileName = Environ$("USERPROFILE") & "\Desktop\" + Mid(swApp.ActiveDoc.GetPathName, Pos1, (Pos2 - Pos1)) + ".pdf"  ' Speichern als PDF-Datei auf dem Desktop
Part.SaveAs2 saveFileName, 0, True, False

' Arbeitsverzeichnis = GetSetting("SPI-Dateizwischenspeichern", "Config", "Arbeitsverzeichnis")
If Right(Arbeitsverzeichnis, 1) <> "\" Then Arbeitsverzeichnis = Arbeitsverzeichnis + "\"
ZeitAlsDateiname = Arbeitsverzeichnis + ZeitAlsDateiname


End Sub

Über Hilfe wären wir dankbar.

Gruß

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Klopfer195
Mitglied
Konstrukteur


Sehen Sie sich das Profil von Klopfer195 an!   Senden Sie eine Private Message an Klopfer195  Schreiben Sie einen Gästebucheintrag für Klopfer195

Beiträge: 27
Registriert: 05.02.2019

SolidWorks 2019 SP5

erstellt am: 24. Jan. 2020 08:21    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für mareike29 10 Unities + Antwort hilfreich

Hallo Mareike,
funktioniert euer Makro denn bisher?
Weil in dieser Zeile

          If AktuellesDokTyp = 3 Then saveFileName = Environ$("USERPROFILE") & "\Desktop\" + Mid(swApp.ActiveDoc.GetPathName, Pos1, (Pos2 - Pos1)) + ".pdf"  ' Speichern als PDF-Datei auf dem Desktop

ist glaube ich ein kleiner Fehler, eure Dateinamen in der PDF müssten momentan ein "\" zu viel haben.

Zu deiner eigentlichen Frage, du müsstest dir den aktuellen Dateinamen in eine Variable schreiben und diese über eine Userform ändern.
Danach kannst du die Datei speichern und "Mid(swApp.ActiveDoc.GetPathName, Pos1, (Pos2 - Pos1))" durch deine neue Variable ersetzten.

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

TMS-TB
Mitglied
Konstrukteur


Sehen Sie sich das Profil von TMS-TB an!   Senden Sie eine Private Message an TMS-TB  Schreiben Sie einen Gästebucheintrag für TMS-TB

Beiträge: 34
Registriert: 30.07.2012

erstellt am: 24. Jan. 2020 08:32    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für mareike29 10 Unities + Antwort hilfreich

Als Beispiel:

    Dim strFileNamePart        As String
    Dim varSplit                As Variant
    Dim intSplitMax            As Integer
    Dim strFileName            As String
   
    strFileNamePart = swModel.GetPathName
    varSplit = Split(strFileNamePart, "\")
    intSplitMax = UBound(varSplit)
   
    strFileName = varSplit(intSplitMax)
    strFileName = Left(strFileName, Len(strFileName) - 7)
    Textbox.Text = strFileName

Nun steht der aktuelle Speichername in einer Textbox, dieser kann dann in einer Form einfach geändert werden und dann als neuer Dateiname später eingesetzt werden.
 

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2024 CAD.de | Impressum | Datenschutz