Save Current Output Windows
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | 'Begin Description 'This script demonstrates how arguments can be passed into a script when 'the script is run using the SCRIPT command in a syntax file. 'To run this script, open 'SaveClose.sps' syntax file and run the 'syntax. The script saves the designated Viewer file as the name 'specified by the argument in the SPSS directory. 'Requirements: The script must be run from the 'SaveClose.sps' syntax 'file. 'SCRIPT file="c:\\program files\\spss\\scripts\\SaveClose.sbs" /("FileName.spo") . 'Source SPSSSNet 100006745 Option Explicit Sub Main 'limit the number of open windows 'Const MAX_WINDOWS As Integer = 10 'Used to save the currently open Viewer doc 'and create a new Viewer doc Dim objOutputDoc As ISpssOutputDoc Dim strParam As String Dim i As Integer Dim objDocuments As ISpssDocuments Set objDocuments = objSpssApp.Documents strParam = objSpssApp.ScriptParameter(0) If objDocuments.OutputDocCount > 0 And strParam <> "" Then Set objOutputDoc = objSpssApp.GetDesignatedOutputDoc 'Remove the ' from the following line to print all output: 'objOutputDoc.PrintDoc 'check to see if the user specified a path If InStr(strParam, "\\") > 0 Then objOutputDoc.SaveAs strParam Else 'if no path specified, use the current directory objOutputDoc.SaveAs objSpssApp.GetSPSSPath & strParam End If End If 'open a new window and make it visible 'objSpssApp.NewOutputDoc.Visible = True 'or just open a new window (e.g. for Production Mode) objSpssApp.NewOutputDoc 'and close the old ones ... 'but only if it's not designated, 'and there are fewer than MAX_WINDOWS 'If objDocuments.OutputDocCount < MAX_WINDOWS Then Exit Sub For i = objDocuments.OutputDocCount - 1 To 0 Step -1 Set objOutputDoc = objDocuments.GetOutputDoc(i) If Not objOutputDoc.Designated Then objOutputDoc.Close End If Next End Sub |
Related pages
...