运行自定义任务

您可排定任务以使用您指定的宏或命令行变元运行任何应用程序。

参阅 SOLIDWORKS API 和插件帮助主题了解有关 SOLIDWORKS 宏文件的信息。
您可从 Windows 开始 > 运行 运行的任何内容都可在 SOLIDWORKS Task Scheduler 中作为自定义任务运行。 参阅您想运行的应用程序中的帮助文件了解有关该应用程序中程序命令行变元和宏的信息。

在“运行自定义任务”中生成任务

要在运行自定义任务中生成任务:

  1. 单击提要字段上的运行自定义任务 ,或单击任务 > 运行自定义任务
  2. 在对话框中,键入任务的新标题或保留任务标题中的默认值。
  3. 程序路径中键入您想运行的程序的路径,或单击浏览将之找出。
  4. 如果程序需要任何程序变元,在程序变元中将之键入。
    SOLIDWORKS 程序变元 程序变元定义 默认设置
    /b 在后台运行 SOLIDWORKS 软件
    /m 运行 SOLIDWORKS 宏
  5. 要运行宏或 SOLIDWORKS 宏模板,在 宏文件路径 中键入路径,或单击 浏览 将之找出。
    如果您指定了 SOLIDWORKS 宏模板,名称符记及其类型会显示在 参数名称 中,以及 任务参数 下的 类型 列。
  6. 在显示参数名称类型的每行中,在参数字串列中单击并键入参数值。
如果您指定一个 SOLIDWORKS 宏模板,在排定或运行任务之前创建宏模板文件的备份,或者将宏模板文件储存在任务工作目录以外的位置。 单击 视图 > 选项 > 任务选项 查看任务工作目录。

生成 SOLIDWORKS 宏模板

SOLIDWORKS 宏模板是 SOLIDWORKS 宏,可当您在 SOLIDWORKS Task Scheduler 中将之排定为自定义任务时由您指定参数值。 SOLIDWORKS 宏模板是文本文件,通常包含 Visual Basic 代码、SOLIDWORKS API 调用及名称符记。 当您排定 SOLIDWORKS 宏模板作为自定义任务在 SOLIDWORKS Task Scheduler 中运行时,您指定参数值代替名称符记。

名称符记可以是文本字符串或数字。 它们格式化如下:

参数类型 名称符记的格式
字符串 $$$<名称符记>$$$
数量 ###<名称符记>###

SOLIDWORKS 宏模板必须具有 .swb 文件扩展名。

要生成宏模板:

  1. 使用 Windows 记事本、Microsoft WordPad、或其它文本编辑器打开新文本文件。
  2. 将 SOLIDWORKS 宏复制并粘贴到文本文件中。
    参阅 SOLIDWORKS API 和插件帮助主题了解有关 SOLIDWORKS 宏文件的信息。
  3. 键入名称符记取代您想指定其值的参数。 例如:
    原有代码: swApp.SetCurrentWorkingDirectory "c:\temp"
    修改过的代码: swApp.SetCurrentWorkingDirectory $$$TASK_WORKING_DIR$$$
  4. 以文件名扩展名 .swb 保存文本文件。
    在排定或运行之前创建 SOLIDWORKS 宏模板文件的备份,或者将 SOLIDWORKS 宏模板文件储存在任务工作目录以外的位置。 单击 视图 > 选项 > 任务选项 查看任务工作目录。 当使用 SOLIDWORKS 宏模板的任务运行时,系统创建宏模板的副本,并以您在排定任务时指定的参数值替换名称符记。 系统将文件保存在与原有 SOLIDWORKS 宏模板相同文件名称下的任务工作目录中。 如果原有 SOLIDWORKS 宏模板储存在任务工作目录中,系统会以新文件将之盖写。
    以下代码是 SOLIDWORKS 宏模板的范例。它将在文件夹中打开每个 SOLIDWORKS 工程图文档并将其保存为 DXF 文件。当您在 SOLIDWORKS Task Scheduler 中排定宏模板为自定义任务时,您指定参数替换名称符记:$$$TASK_SOURCE_DIR$$$$$$TASK_DESTINATION_DIR$$$
    Dim swApp As Object
    Dim swModel As Object
    Dim ret As Boolean
    Dim openError As Long
    Dim openWarn As Long
    Dim errorFilePath As String
    Dim nErrors As Long
    Dim nWarnings As Long
    Dim destinationPath As String
    Dim sourcePath As String
    Dim modelTitle As String
    
    Sub main()
    
        sourcePath = $$$TASK_SOURCE_DIR$$$
        destinationPath = $$$TASK_DESTINATION_DIR$$$
         
        errorFilePath = destinationPath + "\" + "swTaskScheduler.error"
        ErrorOut "Start logging any errors...", errorFilePath
        
        Set swApp = CreateObject("SldWorks.Application")
        swApp.SetCurrentWorkingDirectory destinationPath
        
        ' Determine type of document
        
        openWarn = 0
        
        Dim fileName As String
        fileName = Dir(sourcePath + "\*.SLDDRW")
        
        Do While fileName <> ""
            modelTitle = ""
            Set swModel = swApp.OpenDoc6(sourcePath + "\" + fileName, 3, 1, "", openError, openWarn)
            
            
            If (openWarn And 2) Then
                ErrorOut "File is read-only.", errorFilePath
                ret = False
            ElseIf (openWarn And 4) Then
                ErrorOut "File is locked by another user.", errorFilePath
                ret = False
            ElseIf (openWarn And 512) Then
                ErrorOut "File is view-only.", errorFilePath
                ret = False
            Else
                ret = True
            End If
            
            If Not swModel Is Nothing Then
                modelTitle = swModel.GetTitle()
                If ret = True Then
                        ' Strip off SOLIDWORKS drawing file extension (.slddrw)
                        ' and add DXF file extension (.dxf)
                        Dim sPathName As String
                        sPathName = swModel.GetPathName
                        sPathName = Left(sPathName, Len(sPathName) - 6)
                        sPathName = sPathName + "dxf"
                        sPathName = Replace(sPathName, sourcePath, destinationPath)
                        ' Save as file as DXF
                        bRet = swModel.SaveAs4(sPathName, swSaveAsCurrentVersion, swSaveAsOptions_Silent, nErrors, nWarnings)
                End If
                
                Set swModel = Nothing
                swApp.CloseDoc modelTitle
            End If
    
            
            fileName = Dir
        Loop
              
        ' Exit the SOLIDWORKS software
        swApp.ExitApp
        Set swApp = Nothing
        
    End Sub
    
    Function ErrorOut(errorString As String, errorFilePath As String)
        Open errorFilePath For Append As #5
        Print #5, errorString
        Close #5
    End Function
    

排定任务

欲排定任务:

  1. 任务排程下,设置:
    选项 描述
    运行模式 指定任务运行的频率。选择一次每天每周每月
    开始时间  
    开始日期  
  2. 单击完成
    该任务及其标题、安排时间、安排日期和状态会出现在 任务 面板上。 任务的状态为 已安排
    要运行安排的任务,您的计算机必须处于安排的开始时间。 不需要打开 SOLIDWORKS Task Scheduler 窗口。 如果您的计算机在所排定的开始时间时关闭,则任务在您打开您的计算机时会运行。

    在安排的开始时间,任务开始启动。 如果任务使用 SOLIDWORKS 宏模板,系统会创建宏模板的副本,并以您指定的参数值替换名称符记,然后将文件保存在与原有 SOLIDWORKS 宏模板相同文件名称下的任务工作目录中。 将执行程序和宏命令。

    任务完成时,状态是进展中。 当退出计划的程序时,状态变为完成