使用表单中的参数调用脚本

时间:2012-12-11 17:57:22

标签: shell vb6 vbscript

我有一个表单应该按下按钮调用脚本。我试图通过命令行调用它。我在命令行中测试了脚本,它可以正常工作。我无法获取表单在命令shell中运行脚本。有任何想法吗?

这是我需要由shell自主运行的命令行字符串:

cscript.exe proc_image.vbs 170.191.XXX.XXX picName C:\PicStorage

这是我目前在我的按钮中的On_Click()动作中所拥有的:

 ShellEx "cscript.exe C:\Scripts\proc_image.vbs" & " 170.191.XXX.XXX" & " picName" & " PicStorage"

我的目标是调用脚本并传递3个参数:IP地址,图片名称和最终存储目标。我的问题是让表单在shell中执行上面的命令行。感谢

编辑:这是ShellEx代码:

              Private Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecuteA" _
(ByVal hWnd As Long, ByVal lpOperation As String, _
ByVal lpFile As String, ByVal lpParameters As String, _
ByVal lpDirectory As String, ByVal nShowCmd As Long) As Long

Private Declare Function ShellExecuteForExplore Lib "shell32.dll" Alias "ShellExecuteA" _

(ByVal hWnd As Long, ByVal lpOperation As String, ByVal lpFile As String, lpParameters  As Any, _
lpDirectory As Any, ByVal nShowCmd As Long) As Long

 Public Enum EShellShowConstants
essSW_HIDE = 0
essSW_MAXIMIZE = 3
essSW_MINIMIZE = 6
essSW_SHOWMAXIMIZED = 3
essSW_SHOWMINIMIZED = 2
essSW_SHOWNORMAL = 1
essSW_SHOWNOACTIVATE = 4
essSW_SHOWNA = 8
essSW_SHOWMINNOACTIVE = 7
essSW_SHOWDEFAULT = 10
essSW_RESTORE = 9
essSW_SHOW = 5
End Enum

 Private Const ERROR_FILE_NOT_FOUND = 2&
 Private Const ERROR_PATH_NOT_FOUND = 3&
 Private Const ERROR_BAD_FORMAT = 11&
 Private Const SE_ERR_ACCESSDENIED = 5        ' access denied
 Private Const SE_ERR_ASSOCINCOMPLETE = 27
 Private Const SE_ERR_DDEBUSY = 30
 Private Const SE_ERR_DDEFAIL = 29
 Private Const SE_ERR_DDETIMEOUT = 28
 Private Const SE_ERR_DLLNOTFOUND = 32
 Private Const SE_ERR_FNF = 2                ' file not found
 Private Const SE_ERR_NOASSOC = 31
 Private Const SE_ERR_PNF = 3                ' path not found
 Private Const SE_ERR_OOM = 8                ' out of memory
 Private Const SE_ERR_SHARE = 26


 Public Function ShellEx( _
    ByVal sFIle As String, _
    Optional ByVal eShowCmd As EShellShowConstants = essSW_SHOWDEFAULT, _
    Optional ByVal sParameters As String = "", _
    Optional ByVal sDefaultDir As String = "", _
    Optional sOperation As String = "open", _
    Optional Owner As Long = 0 _
 ) As Boolean
 Dim lR As Long
 Dim lErr As Long, sErr As Long
If (InStr(UCase$(sFIle), ".EXE") <> 0) Then
    eShowCmd = 0
End If
On Error Resume Next
If (sParameters = "") And (sDefaultDir = "") Then
    lR = ShellExecuteForExplore(Owner, sOperation, sFIle, 0, 0, essSW_SHOWNORMAL)
Else
    lR = ShellExecute(Owner, sOperation, sFIle, sParameters, sDefaultDir, eShowCmd)
End If
If (lR < 0) Or (lR > 32) Then
    ShellEx = True
Else
    ' raise an appropriate error: *ERROR CODES GO HERE*
           End If


  End Function

1 个答案:

答案 0 :(得分:0)

看起来你在PicStorage字符串之前的ShellEx命令中缺少C:\