找回密码 注册 QQ登录
一站式解决方案

iCAx开思网

CAD/CAM/CAE/设计/模具 高清视频【积分说明】如何快速获得积分?快速3D打印 手板模型CNC加工服务在线3D打印服务,上传模型,自动报价
查看: 47459|回复: 237
打印 上一主题 下一主题

[原创] SolidWorks图号名称分离宏--不依赖空格或特殊符号

  [复制链接]
跳转到指定楼层
1
发表于 2018-10-12 17:46:46 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多同行朋友,交流,分享,学习。

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 s78763036 于 2018-10-13 09:39 编辑

看论坛的分离宏都是以零件名中的空格或者斜杠为准进行分割,如果零件名不包含这些就无法分离,现在我自己琢磨了一个方法,不需要这些特殊符号,经测试可以准确识别分离以下几种情况:
1图号+名称的情况 ,例如:ABC123固定板,分离成图号:ABC123,名称:固定板
2名称+图号的情况, 例如:固定板ABC123,分离成图号:ABC123,名称:固定板
3纯名称,不包含图号的情况,例如:固定板,将全部写入“名称”属性
4纯图号,不包含名称的情况,例如:ABC123,将全部写入“图号”属性
以下为代码,写的不规范美观,但是能用
游客,如果您要查看本帖隐藏内容请回复







补充内容 (2019-12-2 11:13):
今天发现代码里有错误,现在修改如下:把13行删除,改成以下代码
   e = Right(c, 7)
If e = ".SLDPRT" Or e = ".SLDASM" Or e = ".sldprt" Or e = ".sldasm" Then
   G = Left(c, B - 7)
Else
   G = c
End If

补充内容 (2019-12-2 22:22):
最新宏代码在157楼

评分

参与人数 1技术 +1 贡献 +10 收起 理由
Francis + 1 + 10 值得鼓励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏22 分享淘帖 赞一下!赞一下!
推荐
发表于 2019-12-2 22:22:09 | 只看该作者
本帖最后由 s78763036 于 2019-12-3 09:40 编辑

这是最新修改过的,更改了判断方法,希望能帮助大家,没学过编程,代码乱写的,但是能用
  1. Sub MAIN()
  2. Set swApp = CreateObject("sldworks.application")
  3. Set Part = swApp.ActiveDoc
  4. swApp.ActiveDoc.ActiveView.FrameState = 1
  5. Set CurCFG = Part.GetActiveConfiguration()
  6. ConfName = CurCFG.Name
  7. Name = swApp.ActiveDoc.GetTitle()
  8.   c = Replace(Name, " ", "")
  9. blnretval = Part.AddCustomInfo3(ConfName, "代号", swCustomInfoText, frmPartID)
  10. blnretval = Part.AddCustomInfo3(ConfName, "名称", swCustomInfoText, frmPartID)
  11.    b = Len(c)
  12.    e = Right(c, 7)
  13. If e = ".SLDPRT" Or e = ".SLDASM" Or e = ".sldprt" Or e = ".sldasm" Then
  14.    f = Left(c, b - 7)
  15. Else
  16.    f = c
  17. End If
  18. k = Len(f)
  19. kk = LenB(StrConv(f, vbFromUnicode))   
  20. If k = kk Then '纯数字的情况
  21.     s = ""
  22.     t = f
  23.     Response = MsgBox("文件名不包含零件名称,已整体写入“代号”属性栏", vbOKOnly, "未读取到零件名称") '窗口提示,不需要提示可以删除本行
  24. Else
  25.     If kk / k = 2 Then  '纯汉字的情况
  26.         t = ""
  27.         s = f
  28.         Response = MsgBox("文件名不包含代号,已整体写入“名称”属性栏", vbOKOnly, "未读取到零件代号") '窗口提示,不需要提示可以删除本行
  29.     Else
  30.         For i = 1 To k
  31.             If Asc(Mid$(f, i, 1)) < 0 Then
  32.                 w = i '确定第一个汉字的位置
  33.         Exit For
  34.             End If
  35.         Next
  36.         If w = 1 Then                '名称+代号的情况
  37.             s = Left(f, kk - k)
  38.             t = Right(f, k - (kk - k))
  39.         Else                         '代号+名称的情况
  40.             s = Right(f, k - w + 1)
  41.             t = Left(f, w - 1)
  42.         End If
  43.     End If
  44. End If
  45. dummy = Part.Extension.CustomPropertyManager(Part.ConfigurationManager.ActiveConfiguration.Name).Set("代号", t)
  46. dummy = Part.Extension.CustomPropertyManager(Part.ConfigurationManager.ActiveConfiguration.Name).Set("名称", s)
  47. End Sub
复制代码


推荐
发表于 2019-12-2 10:38:24 | 只看该作者
xiabulai 发表于 2019-3-17 18:11
冒昧的问一下,楼主遍历的图号名称分离宏能分享一下吗,不能分享也没关系

这是遍历宏加入分离宏,但是并不是绝对的稳定,有时候会出错

Dim TopDocPathOnly As String
Dim PartsCollect() As String '遍历清单(阵列)111
Dim InCollectCount As Double '遍历清单长度
Dim CustomInfoQTY As String

Sub main()
Set swApp = Application.SldWorks 'SW对象
Set TopDoc = swApp.ActiveDoc '总装对象
If TopDoc.GetType <> 2 Then Exit Sub '不是装配=退出
TopDocPathSplit = Split(TopDoc.GetPathName, "") '分割
TopDocName = TopDocPathSplit(UBound(TopDocPathSplit)) '总装文件名称
TopDocName = Left(TopDocName, Len(TopDocName) - 7) '总装文件名称(排除.SLDASM)
TopDocPathOnly = Mid(TopDoc.GetPathName, 1, InStrRev(TopDoc.GetPathName, "", -1)) '總裝整個目錄名稱
TopConfString = TopDoc.GetActiveConfiguration.Name '總裝配置名稱
CustomInfoQTY = "数量" '可按个人喜好修改预设值
InCollectCount = 1 '遍历清单长度基数
ReDim PartsCollect(InCollectCount) '定义阵列项数
SubAsm TopDoc, TopConfString '遍历
Beep
MsgBox "完成"
End Sub

Function SubAsm(AsmDoc, ConfString)
Set swApp = Application.SldWorks 'SW对象
Set TopDoc = swApp.ActiveDoc '总装对象
TopDocPathSplit = Split(TopDoc.GetPathName, "") '分割
TopDocName = TopDocPathSplit(UBound(TopDocPathSplit)) '总装文件名称
TopDocName = Left(TopDocName, Len(TopDocName) - 7) '总装文件名称(排除.SLDASM)
TopDocPathOnly = Mid(TopDoc.GetPathName, 1, InStrRev(TopDoc.GetPathName, "", -1)) '總裝整個目錄名稱
TopConfString = TopDoc.GetActiveConfiguration.Name '總裝配置名稱
Set Configuration = AsmDoc.GetConfigurationByName(ConfString)
Set RootComponent = Configuration.GetRootComponent
Components = RootComponent.GetChildren
For Each Child In Components
    Set ChildModel = Child.GetModelDoc
    If Not (ChildModel Is Nothing) Then '排除抑制及轻化
        ChildConfString = Child.ReferencedConfiguration '零件配置名称
        ChildType = ChildModel.GetType
            ChildPathSplit = Split(Child.GetPathName, "") '分割
            ChildName = ChildPathSplit(UBound(ChildPathSplit)) '零件文件名称
            ChildPathOnly = Mid(Child.GetPathName, 1, InStrRev(Child.GetPathName, "", -1)) '總裝整個目錄名稱
            If ChildPathOnly = Replace(ChildPathOnly, TopDocPathOnly, "") Then SamePath = False Else SamePath = True '零件是否在总装目录或以下目录
            If (Not Child.ExcludeFromBOM) And (Not Child.IsEnvelope) Then '跳过:不包括在材料明細表中 及 封套

                BYL_Name = ChildModel.CustomInfo2(ChildConfString, "BYL") '备用量属性名称
                BYL = ChildModel.CustomInfo2(ChildConfString, BYL_Name) '备用量
                If (BYL = 0) Or (BYL = "") Then BYL = 1 '备用量除错
                inCollect = False '重置判断变量
                For Each PartinCollect In PartsCollect '判断是否已在遍历清单內
                    If ChildConfString & "@" & ChildName = PartinCollect Then inCollect = True
                Next
                If inCollect Then '已在遍历清单內
                    ht_Qty = ChildModel.CustomInfo2(ChildConfString, CustomInfoQTY) + 1 * BYL
                    ChildModel.DeleteCustomInfo2 ChildConfString, CustomInfoQTY
                    ChildModel.AddCustomInfo3 ChildConfString, CustomInfoQTY, 30, ht_Qty
                Else '不在遍历清单內(首次处理)
                    ChildModel.DeleteCustomInfo2 ChildConfString, CustomInfoQTY
                    ChildModel.AddCustomInfo3 ChildConfString, CustomInfoQTY, 30, BYL
                    InCollectCount = InCollectCount + 1
                    ReDim Preserve PartsCollect(InCollectCount) '重新定义阵列项数(保留內含数据)
                    PartsCollect(InCollectCount - 1) = ChildConfString & "@" & ChildName '加入到遍历清单中
                    ChildModel.SetUserPreferenceIntegerValue swUnitSystem, swUnitSystem_Custom '单位系统=Custom
                    ChildModel.SetUserPreferenceIntegerValue swUnitsMassPropMass, swUnitsMassPropMass_Kilograms '重量单位设定为kg(可按喜好加入設定)
                                    ChildModel.SetUserPreferenceIntegerValue swUnitsMassPropMass, swUnitsMassPropMass_Grams '设质量定单位为克
                ChildModel.DeleteCustomInfo2 "", "重量" '删除重量自定义属性
                ChildModel.DeleteCustomInfo2 ChildConfString, "重量" '删除重量配置特定属性
                ChildModel.AddCustomInfo3 ChildConfString, "重量", 30, Chr(34) & "SW-Mass@@" & ChildConfString & "@*" & ChildName & Chr(34) '加入重量配置特定属性
                ChildModel.SetUserPreferenceIntegerValue swUnitsMassPropLength, swCM '设定体积单位为厘米
                ChildModel.SetUserPreferenceIntegerValue swUnitsMassPropVolume, swUnitsMassPropVolume_Centimeters3 '设定单位每立方厘米
                ChildModel.DeleteCustomInfo2 "", "体积" '删除体积自定义属性
                ChildModel.DeleteCustomInfo2 ChildConfString, "体积" '删除体积配置特定属性
                ChildModel.AddCustomInfo3 ChildConfString, "体积", 30, Chr(34) & "SW-Volume@@" & ChildConfString & "@*" & ChildName & Chr(34) '加入体积配置特定属性
                ChildModel.SetUserPreferenceIntegerValue swUnitsMassPropDecimalPlaces, 8 '质量及体积小数后8位
               ConfName = ChildModel.GetActiveConfiguration.Name
                Set CustPropMgr = ChildModel.Extension.CustomPropertyManager(ConfName)

                Path_Name = ChildModel.GetPathName() '取得"路径名称及扩展名",不管扩展名是否应藏
                S1 = InStrRev(Path_Name, "\") '\符号在路径之最后位置数
                Name_C = Right(Path_Name, Len(Path_Name) - S1) '取得件号_名称.扩展名"

b = Len(Name_C)
e = Right(Name_C, 7)

If e = ".SLDPRT" Or e = ".SLDASM" Or e = ".sldprt" Or e = ".sldasm" Then
   g = Left(Name_C, b - 7)
Else
   g = Name_C
End If

   k = Len(g)

For I = 1 To Len(g)
   If Asc(Mid$(g, I, 1)) < 0 Then
      w = I  '确定第一个汉字的位置
   Exit For
   End If
Next

For I = 0 To Len(g) - 1
   If Asc(Mid$(g, k - I, 1)) < 0 Then
      X = k - I  '确定最后一个汉字的位置
   Exit For
   End If
Next

If w > 0 Then
  If w = 1 Then
     s = Left(g, X) '汉字在前数字在后的情况
     T = Right(g, k - X)
  Else
     s = Right(g, k - w + 1) '数字在前汉字在后的情况
     T = Left(g, w - 1)
  End If
Else
  s = "" '纯数字的情况
  T = g


End If

If k - ((X - w) + 1) = 1 Or k - ((X - w) + 1) = 0 Then  '纯名称的情况
  T = ""
  s = g

Else
End If


                '删除栏
                CustPropMgr.Delete ("代号")
                CustPropMgr.Delete ("名称")
                CustPropMgr.Delete ("客户")

                '新增
                CustPropMgr.Add2 "代号", swCustomInfoText, T
                CustPropMgr.Add2 "名称", swCustomInfoText, s
                CustPropMgr.Add2 "客户", swCustomInfoText, TopConfString


                ChildModel.SketchManager.Insert3DSketch True '插入三低草图
                ChildModel.SketchManager.Insert3DSketch True '离开三低草图
                End If
                 If ChildType = 2 Then
            SubAsm ChildModel, ChildConfString '如果是装配则向下遍历
            End If

        End If
    End If
Next
End Function


2
发表于 2018-10-12 20:14:52 | 只看该作者
谢谢分享
3
发表于 2018-10-13 10:10:56 | 只看该作者
下载来试试
4
发表于 2018-10-13 10:40:59 | 只看该作者
@Francis,闷大,我有一个问题,我把分离宏加入遍历宏,可以实现分离图号名称,但是我装配体有一些标准件,GB开头的,这些零件我不需要遍历进行分离图号名称写入属性,我想知道如何把GB开头的不包含在遍历清单中,自己捣鼓没结果,望指教,谢谢!
5
发表于 2018-10-13 12:59:37 | 只看该作者
22222222222222222222222222222222
6
发表于 2018-10-13 18:14:34 | 只看该作者
社么好东西,我喜欢
7
发表于 2018-10-13 23:00:05 | 只看该作者
谢谢楼主分享!
8
发表于 2018-10-13 23:04:56 | 只看该作者
有一种特例,有时名称中会包含有字母或数字,如何处理?
9
发表于 2018-10-14 16:21:22 | 只看该作者
s78763036 发表于 2018-10-13 10:40
@Francis,闷大,我有一个问题,我把分离宏加入遍历宏,可以实现分离图号名称,但是我装配体有一些标准件, ...

看得出樓主有點焦急(應該是焦躁吧),還是過多幾天,待樓主冷靜一點,再來討論,應該可以水到渠成的。
10
发表于 2018-10-14 16:24:20 | 只看该作者
謝謝分享學習了!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

3D打印手板模型快速制作服务,在线报价下单!

QQ 咨询|手机版|联系我们|iCAx开思网  

GMT+8, 2025-1-21 05:58 , Processed in 0.033097 second(s), 13 queries , Gzip On, Redis On.

Powered by Discuz! X3.3

© 2002-2025 www.iCAx.org

快速回复 返回顶部 返回列表