Перейдем к описанию собственной объектной модели Windows Script Host. С помощью внутренних объектов WSH из сценариев можно выполнять следующие основные задачи:
В WSH версии 5.6 (стандартная версия в Windows XP) входят перечисленные ниже объекты:
Кроме этого, имеется объект FileSystemObject, обеспечивающий доступ к файловой системе компьютера (этот объект будет подробно рассмотрен в следующей лекции).
Рассмотрим более подробно несколько объектов WSH, которые часто используются в сценариях.
Свойства объекта WScript позволяют получить полный путь к использующемуся серверу сценариев (wscript.exe или cscript.exe), параметры командной строки, с которыми запущен сценарий, режим его работы (интерактивный или пакетный). Кроме этого, с помощью свойств объекта WScript можно выводить информацию в стандартный выходной поток и читать данные из стандартного входного потока. Также WScript предоставляет методы для работы внутри сценария с объектами автоматизации и вывода информации на экран (в текстовом режиме) или в окно Windows.
Отметим, что в сценарии WSH объект WScript можно использовать сразу, без какого-либо предварительного описания или создания, так как его экземпляр создается сервером сценариев автоматически. Для использования же всех остальных объектов нужно использовать либо метод CreateObject, либо определенное свойство другого объекта.
Свойства объекта WScript представлены в табл. 5.1.
Свойство | Описание |
Application | Предоставляет интерфейс Idispatch для объекта WScript |
Arguments | Содержит указатель на коллекцию WshArguments, содержащую параметры командной строки для исполняемого сценария |
FullName | Содержит полный путь к исполняемому файлу сервера сценариев (в Windows XP обычно это C:\WINDOWS\SYSTEM32\CSCRIPT.EXE или C:\WINDOWS\SYSTEM32\WSCRIPT.EXE) |
Name | Содержит название объекта Wscript (Windows Script Host) |
Path | Содержит путь к каталогу, в котором находится cscript.exe или wscript.exe (в Windows XP обычно это C:\WINDOWS\SYSTEM32) |
ScriptFullName | Содержит полный путь к запущенному сценарию |
ScriptName | Содержит имя запущенного сценария |
StdErr | Позволяет запущенному сценарию записывать сообщения в стандартный поток для ошибок |
StdIn | Позволяет запущенному сценарию читать информацию из стандартного входного потока |
StdOut | Позволяет запущенному сценарию записывать информацию в стандартный выходной поток |
Version | Содержит версию WSH |
Опишем более подробно некоторые свойства объекта WScript.
В следующем примере (листинг 5.1) с помощью цикла For Each … Next на экран выводятся все параметры командной строки, с которыми был запущен сценарий.
'******************************************************************** ' Имя: Args.vbs ' Язык: VBScript ' Описание: Работа с аргументами запущенного сценария '******************************************************************** Option Explicit Dim s,objArgs,Arg Set objArgs = WScript.Arguments ' Создаем объект WshArguments For Each Arg In objArgs s=s & Arg ' Формируем строки со значениями аргументов Next WScript.Echo s ' Выводим сформированные строки '************* Конец *********************************************Листинг 5.1. Вывод всех параметров командной строки сценария (VBScript)
Доступ к стандартным входным и выходным потокам с помощью свойств StdIn, StdOut и StdErr можно получить только в том случае, если сценарий запускался в консольном режиме с помощью cscript.exe. Если сценарий был запущен с помощью wscript.exe, то при попытке обратиться к этим свойствам возникнет ошибка "Invalid Handle".
Работать с потоками StdOut и StdErr можно с помощью методов Write, WriteLine, WriteBlankLines, а с потоком StdIn — с помощью методов Read, ReadLine, ReadAll, Skip, SkipLine. Эти методы кратко описаны в табл. 5.2.
Метод | Описание |
---|---|
Read(n) | Считывает из потока StdIn заданное параметром n число символов и возвращает полученную строку |
ReadAll() | Читает символы из потока StdIn до тех пор, пока не встретится символ конца файла ASCII 26 (<Ctrl>+<Z>), и возвращает полученную строку |
ReadLine() | Возвращает строку, считанную из потока StdIn |
Skip(n) | Пропускает при чтении из потока StdIn заданное параметром n число символов |
SkipLine() | Пропускает целую строку при чтении из потока StdIn |
Write(string) | Записывает в поток StdOut или StdErr строку string (без символа конца строки) |
WriteBlankLines(n) | Записывает в поток StdOut или StdErr заданное параметром n число пустых строк |
WriteLine(string) | Записывает в поток StdOut или StdErr строку string (вместе с символом конца строки) |
Напомним, что операционная система Windows поддерживает механизм конвейеризации (символ "|" в командной строке). Этот механизм делает возможным передачу данных от одной программы к другой. Таким образом, используя стандартные входные и выходные потоки, можно из сценария обрабатывать строки вывода другого приложения или перенаправлять выводимые сценарием данные на вход программ-фильтров ( FIND или SORT ). Например, следующая команда будет сортировать строки вывода сценария example.js и выводить их в файл sort.txt:
cscript //Nologo example.js | sort > sort.txt
Опция //Nologo здесь нужна для того, чтобы в файл sort.txt не попадали строки с информацией о разработчике и номере версии WSH.
Кроме этого, с помощью методов, работающих с входным потоком StdIn, можно организовывать диалог с пользователем, то есть создавать интерактивные сценарии. Соответствующий пример приведен в листинге 5.2.
'******************************************************************* '* Имя: Interact.vbs '* Язык: VBScript '* Описание: Ввод/вывод строк в консольном режиме '******************************************************************* Dim s ' Выводим строку на экран WScript.StdOut.Write "Введите число: " ' Считываем строку s = WScript.StdIn.ReadLine ' Выводим строку на экран WScript.StdOut.WriteLine "Вы ввели число " & s '************* Конец *********************************************Листинг 5.2. Ввод/вывод строк в символьном режиме