Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  SolidWorks
  Stüli via Makro in Excel auslesen

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 stärkt PLM-Geschäft mit Neugründung
Autor Thema:  Stüli via Makro in Excel auslesen (1644 mal gelesen)
Cuprar
Mitglied
Konstrukteur

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

Beiträge: 6
Registriert: 11.02.2014

erstellt am: 11. Feb. 2014 21:52    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


Stuliauslesen.zip

 
Hallo zusammen

Ich bin neu hier im Forum und auch noch ein ziemlicher Anfänger was Makros anbelangt.
Auf der Suche nach einer Lösung um die SolidWorks Stüli in eine formatierte Excel Tabelle einzulesen bin ich auf auf den Code von "riesi" gestossen.
Ich konnte Ihn soweit anpassen dass ich die komplette Stüli in Excel einlesen kann.
Das einzige Problem dass ich jetzt noch habe ist, dass die Stüli direkt in der ersten Zeile eingefügt wird.
Da ich einen definierten Blattkopf habe möchte ich dass die Stüli erst ab der dritten oder vierten Zeile eingefügt wird. Evtl. kann mir jemand bei diesem Befehl weiterhelfen.

Sub main()
    Dim swApp                  As Object
    Dim swModel                As Object
    Dim swDraw                  As Object
    Dim swView                  As Object
    Dim swTable                As Object
    Dim swFeat                  As Object
    Dim swBomFeat              As Object
    Dim bRet                    As Boolean
    Dim swAnn                  As Object
    Dim nNumCol                As Long
    Dim nNumRow                As Long
    Dim sRowStr                As String
    Dim sTitStr                As String
    Dim a                      As Long
    Dim j                      As Long
    Dim b                      As Long
    Dim intOutHandle            As Integer
    Dim strOneLine              As String
    Dim SWXBom()                As String
    Dim sZelle                  As String
    Dim Benennung              As Integer
    Dim Mass1Spalte            As Integer
    Dim PosSpalte              As Integer
    Dim MengenSpalte            As Integer
    Dim Zeichnungsnummer        As Integer
    Dim Hersteller              As Integer
    Dim HerstellerSachnummer    As Integer
    Dim ErsatzVerschleiss      As Integer
    Dim NormTyp                As Integer
    Dim Material                As Integer
    Dim Lieferant              As Integer
    Dim Kosten                  As Integer
    Dim xlApp                  As Object

    Set swApp = CreateObject("SldWorks.Application")
    Set swModel = swApp.ActiveDoc

    If swModel Is Nothing Then
        MsgBox "Keine Dokumentnte geöffnet."
        End
    End If

    If swModel.GetType <> swDocDRAWING Then
        MsgBox "Das Dokument ist keine Zeichnung."
        End
    End If

    Set swDraw = swModel

    Set swView = swDraw.GetFirstView
    Set swTable = swView.GetFirstTableAnnotation

 
    If swTable Is Nothing Then
      MsgBox "Die Zeichnung enthält keine Stückliste"
      End
    End If

    Do While swTable.Type <> 2
      Set swTable = swTable.GetNext
      If swTable Is Nothing Then
        MsgBox "Die Zeichnung enthält keine Stückliste"
        End
      End If
    Loop

    ' Debug.Print swTable.Type

    nNumCol = swTable.ColumnCount
    nNumRow = swTable.RowCount
     
    ' Stüli auslesen
    For j = 0 To nNumCol - 1
      sTitStr = Trim(swTable.GetColumnCustomProperty(j))
      If sTitStr = "Benennung" Then
          Benennung = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Zeichnungsnummer" Then
          Zeichnungsnummer = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Lieferant" Then
          Lieferant = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Norm-Typ" Then
          NormTyp = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Material" Then
          Material = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Hersteller" Then
          Hersteller = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Hersteller Sachnummer" Then
          HerstellerSachnummer = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "E/V" Then
          ErsatzVerschleiss = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Kosten" Then
          Kosten = j
          'Debug.Print sTitStr
      End If
          'Debug.Print sTitStr
      sTitStr = Trim(swTable.Text(0, j))
      If sTitStr = "Pos." Then
          PosSpalte = j
          'Debug.Print sTitStr
      ElseIf sTitStr = "Menge" Then
          MengenSpalte = j
          'Debug.Print sTitStr
      End If
      'Debug.Print sTitStr
    Next j
    ReDim SWXBom(nNumRow, 11)
    For a = 0 To nNumRow - 0
      SWXBom(a, 1) = swTable.Text(a, PosSpalte)
      'Debug.Print SWXBom(i, 1)
      SWXBom(a, 2) = swTable.Text(a, MengenSpalte)
      'Debug.Print SWXBom(i, 2)
      SWXBom(a, 3) = swTable.Text(a, Benennung)
      'Debug.Print SWXBom(i, 3)
      SWXBom(a, 4) = swTable.Text(a, Zeichnungsnummer)
      'Debug.Print SWXBom(i, 4)
      SWXBom(a, 5) = swTable.Text(a, HerstellerSachnummer)
      'Debug.Print SWXBom(i, 5)
      SWXBom(a, 6) = swTable.Text(a, ErsatzVerschleiss)
      'Debug.Print SWXBom(i, 6)
      SWXBom(a, 7) = swTable.Text(a, NormTyp)
      'Debug.Print SWXBom(i, 7)
      SWXBom(a, 8) = swTable.Text(a, Material)
      'Debug.Print SWXBom(i, 8)
      SWXBom(a, 9) = swTable.Text(a, Hersteller)
      'Debug.Print SWXBom(i, 9)
      SWXBom(a, 10) = swTable.Text(a, Lieferant)
      'Debug.Print SWXBom(i, 10)

      If swTable.Text(a, Kosten) <> "" Then
        SWXBom(a, 11) = swTable.Text(a, Kosten)
        If Right(SWXBom(a, 11), 2) = "Kosten" Then SWXBom(a, 2) = Left(SWXBom(a, 11), Len(SWXBom(a, 11)) - 2)
        'Debug.Print SWXBom(i, 4)
      End If
    Next a
    Set swApp = Nothing
    Set swModel = Nothing
    Set swDraw = Nothing
    Set swView = Nothing
    Set swTable = Nothing
 
 
    Set xlApp = CreateObject("Excel.Application")
 
    For a = 1 To nNumRow - 2
      For j = 1 To 11
     
        Debug.Print SWXBom(a, j)
        Cells(a, j).Value = SWXBom(a, j)
      Next j
    Next a
 
    Set xlApp = Nothing
End Sub

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

Olls Lai Lolli
Mitglied
Konstrukteur


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

Beiträge: 366
Registriert: 07.05.2009

MS Windows 10 Prof.
Intel Xeon E5-1630 v 3 3.7 GHz
32 GB Ram
Nvidia Quadro M4000
SWX 2019 x64 SP 5
PDM Enterprise 2019 SP 3

erstellt am: 11. Feb. 2014 22:31    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 Cuprar 10 Unities + Antwort hilfreich

Hi Cuprar,

ich hab wahrscheinlich noch viel weniger Ahnung, wie du vom Makro programmieren.

Aber wenn ich das richtig verstanden habe, würde ich die Stelle um den Versatz zu erzeugen hier suchen:

Set xlApp = CreateObject("Excel.Application")

    For a = 1 To nNumRow - 2
      For j = 1 To 11
    
        Debug.Print SWXBom(a, j)
        Cells(a, j).Value = SWXBom(a, j)
      Next j
    Next a

    Set xlApp = Nothing
End Sub


So könnte es vielleicht klappen

Set xlApp = CreateObject("Excel.Application")

    For a = 1 To nNumRow - 2
     b = a + 3 ' Die Zahl entspricht der gewünschten Menge an Leerzeilen
      For j = 1 To 11
    
        Debug.Print SWXBom(a, j)
        Cells(b, j).Value = SWXBom(a, j)
      Next j
    Next a

    Set xlApp = Nothing
End Sub


Wie gesagt, ich bin auch noch "Lehrling" was das Thema Macros an geht, kann auch sein, dass ich total daneben liege.

[Diese Nachricht wurde von Olls Lai Lolli am 11. Feb. 2014 editiert.]

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

Cuprar
Mitglied
Konstrukteur

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

Beiträge: 6
Registriert: 11.02.2014

erstellt am: 11. Feb. 2014 22:47    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

Hi Olls Lai Lolli

Du bist mein Held des Tages 
Ich musste es gleich noch schnell ausprobieren und siehe da es funktioniert einwandfrei.
Vielen Dank für die schnelle Antwort

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

Olls Lai Lolli
Mitglied
Konstrukteur


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

Beiträge: 366
Registriert: 07.05.2009

MS Windows 10 Prof.
Intel Xeon E5-1630 v 3 3.7 GHz
32 GB Ram
Nvidia Quadro M4000
SWX 2019 x64 SP 5
PDM Enterprise 2019 SP 3

erstellt am: 11. Feb. 2014 22:57    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 Cuprar 10 Unities + Antwort hilfreich

Held? 

Ein blindes Huhn findet auch mal ein Korn, ist sicher zutreffender!

Gruß Oll

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

Joshua63
Mitglied
Maschinenbautechniker


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

Beiträge: 371
Registriert: 08.11.2006

W10 SP1
Intel i7 8700K
Quatro P4000
32GB RAM
SW 2021 SP4.1
SWX PDM Professional 2021

erstellt am: 12. Feb. 2014 09:40    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 Cuprar 10 Unities + Antwort hilfreich

Hi,

liest du eine Excelbasierende oder eine SWX-Stüli aus ?

Wir machen es zur Zeit so:

SWX-Stüli als TXT ablegen, dann in eine bestimmte Vorlage wieder einlesen. (wir haben 3 verschiedene Kundenvorlagen)

Es ist quasi ein Makro in SWX das dann ein weiteres in Excel aufruft.

Gruß

------------------
Viele Wege führen zum Ziel .......... und ich will alle wissen !

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

Cuprar
Mitglied
Konstrukteur

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

Beiträge: 6
Registriert: 11.02.2014

erstellt am: 12. Feb. 2014 11:13    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

Hi

Nein wir lesen die Solidworks eigene Stüli aus. Haben aber früher auch mit der Excel basierenden gearbeitet. Mit den Anpassungen funktioniert der Code jetzt wie er sollte, bei mir zuhause jedenfalls 
Habe es heute im Geschäft ausprobiert und jetzt bekomme ich die Meldung das kein Dokument geöffnet ist. Der Code ist so geschrieben dass er erkennt ob wirklich eine Zeichnung mit Stückliste geöffnet ist. Irgendwie erkennt er das nicht. Mal schauen

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