Запуск командной строки молча с VbScript и получение вывода?
Я хочу иметь возможность запускать программу через командную строку, и я хочу запустить ее с помощью VbScript. Я также хочу получить вывод командной строки и назначить его переменной, и я хочу, чтобы все это было сделано тихо, без появления окон cmd. Я справлялся с двумя вещами по отдельности, но не вместе. Вот что мне удалось выяснить. Запустите команду из cmd и получите вывод:
Dim WshShell, oExec
Set WshShell = WScript.CreateObject("WScript.Shell")
Set oExec = WshShell.Exec("C:snmpget -c public -v 2c 10.1.1.2 .1.3.6.1.4.1.6798.3.1.1.1.5.1")
x = oExec.StdOut.ReadLine
Wscript.Echo x
приведенный выше скрипт работает и делает то, что я хочу, за исключением того, что cmd появляется на короткий момент.
вот скрипт, который будет работать молча, но не будет захватывать вывод
Set WshShell = WScript.CreateObject("WScript.Shell")
Return = WshShell.Run("C:snmpset -c public -v 2c -t 0 10.1.1.2 .1.3.6.1.4.1.6798.3.1.1.1.7.1 i 1", 0, true)
есть ли способ заставить этих двоих работать вместе?
позвольте мне дать вам представление о том, почему я хочу сделать это. Я в основном опрашиваю блок каждые 5-10 минут, и я собираюсь получить сценарий по электронной почте или бросить окно сообщения, когда возникает определенное условие, но я не хочу видеть, что строка cmd появляется весь день на моем компьютере. Есть предложения? Спасибо
5 ответов
вы можете перенаправить вывод в файл и затем прочитать файл:
return = WshShell.Run("cmd /c C:\snmpset -c ... > c:\temp\output.txt", 0, true)
Set fso = CreateObject("Scripting.FileSystemObject")
Set file = fso.OpenTextFile("c:\temp\output.txt", 1)
text = file.ReadAll
file.Close
Я взял это и различные другие комментарии и создал немного более продвинутую функцию для запуска приложения и получения вывода.
пример вызова функции: выведет список DIR C:\ только для каталогов. Выход будет возвращено переменной CommandResults а также оставаться в C:\OUTPUT.ФОРМАТ TXT.
CommandResults = vFn_Sys_Run_CommandOutput("CMD.EXE /C DIR C:\ /AD",1,1,"C:\OUTPUT.TXT",0,1)
функции
Function vFn_Sys_Run_CommandOutput (Command, Wait, Show, OutToFile, DeleteOutput, NoQuotes)
'Run Command similar to the command prompt, for Wait use 1 or 0. Output returned and
'stored in a file.
'Command = The command line instruction you wish to run.
'Wait = 1/0; 1 will wait for the command to finish before continuing.
'Show = 1/0; 1 will show for the command window.
'OutToFile = The file you wish to have the output recorded to.
'DeleteOutput = 1/0; 1 deletes the output file. Output is still returned to variable.
'NoQuotes = 1/0; 1 will skip wrapping the command with quotes, some commands wont work
' if you wrap them in quotes.
'----------------------------------------------------------------------------------------
On Error Resume Next
'On Error Goto 0
Set f_objShell = CreateObject("Wscript.Shell")
Set f_objFso = CreateObject("Scripting.FileSystemObject")
Const ForReading = 1, ForWriting = 2, ForAppending = 8
'VARIABLES
If OutToFile = "" Then OutToFile = "TEMP.TXT"
tCommand = Command
If Left(Command,1)<>"""" And NoQuotes <> 1 Then tCommand = """" & Command & """"
tOutToFile = OutToFile
If Left(OutToFile,1)<>"""" Then tOutToFile = """" & OutToFile & """"
If Wait = 1 Then tWait = True
If Wait <> 1 Then tWait = False
If Show = 1 Then tShow = 1
If Show <> 1 Then tShow = 0
'RUN PROGRAM
f_objShell.Run tCommand & ">" & tOutToFile, tShow, tWait
'READ OUTPUT FOR RETURN
Set f_objFile = f_objFso.OpenTextFile(OutToFile, 1)
tMyOutput = f_objFile.ReadAll
f_objFile.Close
Set f_objFile = Nothing
'DELETE FILE AND FINISH FUNCTION
If DeleteOutput = 1 Then
Set f_objFile = f_objFso.GetFile(OutToFile)
f_objFile.Delete
Set f_objFile = Nothing
End If
vFn_Sys_Run_CommandOutput = tMyOutput
If Err.Number <> 0 Then vFn_Sys_Run_CommandOutput = "<0>"
Err.Clear
On Error Goto 0
Set f_objFile = Nothing
Set f_objShell = Nothing
End Function
или найдите назначение вывода в буфер обмена (в первом скрипте), а затем во втором скрипте проанализируйте значение буфера обмена.
Если вы получаете любой другой метод, пожалуйста, предложите мне.
@Mark Cidade
Спасибо!! Это решило несколько дней исследований о том, как я должен называть это из PHP WshShell. Так что, благодаря твоему коду, я понял...
function __exec($tmppath, $cmd)
{
$WshShell = new COM("WScript.Shell");
$tmpf = rand(1000, 9999).".tmp"; // Temp file
$tmpfp = $tmppath.'/'.$tmpf; // Full path to tmp file
$oExec = $WshShell->Run("cmd /c $cmd -c ... > ".$tmpfp, 0, true);
// return $oExec == 0 ? true : false; // Return True False after exec
return $tmpf;
}
Это то, что работало для меня в моем случае. Не стесняйтесь использовать и изменять в соответствии с вашими потребностями. Вы всегда можете добавить функциональность в функцию, чтобы автоматически прочитать файл tmp, назначить его переменной и/или вернуть его, а затем удалить файл tmp. Еще раз спасибо @Mark!
Dim path As String = GetFolderPath(SpecialFolder.ApplicationData)
Dim filepath As String = path + "\" + "your.bat"
' Create the file if it does not exist.
If File.Exists(filepath) = False Then
File.Create(filepath)
Else
End If
Dim attributes As FileAttributes
attributes = File.GetAttributes(filepath)
If (attributes And FileAttributes.ReadOnly) = FileAttributes.ReadOnly Then
' Remove from Readonly the file.
attributes = RemoveAttribute(attributes, FileAttributes.ReadOnly)
File.SetAttributes(filepath, attributes)
Console.WriteLine("The {0} file is no longer RO.", filepath)
Else
End If
If (attributes And FileAttributes.Hidden) = FileAttributes.Hidden Then
' Show the file.
attributes = RemoveAttribute(attributes, FileAttributes.Hidden)
File.SetAttributes(filepath, attributes)
Console.WriteLine("The {0} file is no longer Hidden.", filepath)
Else
End If
Dim sr As New StreamReader(filepath)
Dim input As String = sr.ReadToEnd()
sr.Close()
Dim output As String = "@echo off"
Dim output1 As String = vbNewLine + "your 1st cmd code"
Dim output2 As String = vbNewLine + "your 2nd cmd code "
Dim output3 As String = vbNewLine + "exit"
Dim sw As New StreamWriter(filepath)
sw.Write(output)
sw.Write(output1)
sw.Write(output2)
sw.Write(output3)
sw.Close()
If (attributes And FileAttributes.Hidden) = FileAttributes.Hidden Then
Else
' Hide the file.
File.SetAttributes(filepath, File.GetAttributes(filepath) Or FileAttributes.Hidden)
Console.WriteLine("The {0} file is now hidden.", filepath)
End If
Dim procInfo As New ProcessStartInfo(path + "\" + "your.bat")
procInfo.WindowStyle = ProcessWindowStyle.Minimized
procInfo.WindowStyle = ProcessWindowStyle.Hidden
procInfo.CreateNoWindow = True
procInfo.FileName = path + "\" + "your.bat"
procInfo.Verb = "runas"
Process.Start(procInfo)
это экономит ваше .bat файл в "Appdata текущего пользователя", если он не существует и удалить атрибуты и после этого установите" скрытые " атрибуты в файл после написания кода cmd и запустите его молча и захватить все выходные сохраняет его в файл поэтому, если вы хотите сохранить вывод в cmd в файл просто добавьте свой, как этот
code > C:\Users\Lenovo\Desktop\output.txt
просто замените слово" код " на ваш .bat код файла или команда и после этого каталог выходного файла Недавно я нашел один код поиск много если хочешь бежать .bat файл в vb или c# или просто просто добавьте это так же, как я написал