Листинг 5.9. Вывод даты создания текущего каталога
/*******************************************************************/
/* Имя: DateFolder.js */
/* Язык: JScript */
/* Описание: Вывод на экран даты создания текущего каталога */
/*******************************************************************/
var FSO,WshShell,s; //Объявляем переменные
//Создаем объект FileSystemObject
FSO = WScript.CreateObject("Scripting.FileSystemObject");
//Создаем объект WshShell
WshShell=WScript.CreateObject("WScript.Shell");
//Определяем каталог, из которого был запущен сценарий
//(текущий каталог)
Folder = FSO.GetFolder(WshShell.CurrentDirectory);
//Получаем имя текущего каталога
s="Текущий каталог: "+Folder.Name+"\n";
//Получаем дату создания текущего каталога
s+="Дата создания: "+Folder.DateCreated+"\n";
//Выводим информацию на экран
WScript.Echo(s);
/************* Конец *********************************************/
Методы объекта Folderописаны в табл. 5.9.
Таблица 5.9.Методы объекта Folder
| Метод |
Описание |
Copy( destination [, overwrite] ) |
Копирует каталог в другое место |
CreateTextFile( filename[, overwrite [, unicode]] ) |
Создает новый текстовый файл с именем filenameи возвращает указывающий на этот файл объект TextStream(этот метод аналогичен рассмотренному выше методу CreateTextFileобъекта FileSystemObject) |
Delete( [force] ) |
Удаляет каталог |
| Move( destination ) |
Перемещает каталог в другое место |
Приведем необходимые замечания для методов из табл. 5.9.
Обязательный параметр destination определяет каталог, в который будет производиться копирование; групповые символы в имени каталога недопустимы.
Параметр overwrite является логической переменной, определяющей, следует ли заменять уже существующий каталог с именем destination ( overwrite =true) или нет ( overwrite=false ).
Замечание
Вместо метода Соруможно использовать метод CopyFolderобъекта FileSystemObject.
Если параметр force равен falseили не указан, то с помощью метода Deleteбудет нельзя удалить каталог с атрибутом "только для чтения" (read-only). Установка для force значения true позволит сразу удалять такие каталоги.
При использовании метода Deleteневажно, является ли заданный каталог пустым или нет — он удалится в любом случае.
Замечание
Вместо метода Deleteможно использовать метод DeleteFolderобъекта FileSystemObject.
Обязательный параметр destination определяет каталог, в который будет производиться перемещение; групповые символы в имени каталога недопустимы.
Замечание
Вместо метода Moveможно использовать метод MoveFolderобъекта FileSystemObject.
Коллекция Foldersсодержит объекты Folderдля всех подкаталогов определенного каталога. Создается эта коллекция с помощью свойства SubFoldersсоответствующего объекта Folder. Например, в следующем примере переменная SubFoldersявляется коллекцией, содержащей объекты Folderдля всех подкаталогов каталога C:\Program Files:
var FSO, F, SubFolders;
//Создаем объект FileSystemObject
FSO=WScript.CreateObject("Scripting.FileSystemObject");
//Создаем объект Folder для каталога C:\Program Files
F=FSO.GetFolder("C:\\Program Files");
//Создаем коллекцию подкаталогов каталога C:\Program Files
SubFolders=F.SubFolders;
Коллекция Folders(как и Drives) имеет свойство Countи метод Item. Кроме этого, у Foldersесть метод Add( folderName ), позволяющий создавать новые подкаталоги. В листинге 5.10 приведен сценарий MakeSubFold.js, который создает в каталоге "С:\Мои документы" подкаталог "Новая папка".
Листинг 5.10. Создание нового каталога
/*******************************************************************/
/* Имя: MakeSubFold.js */
/* Язык: JScript */
/* Описание: Создание нового каталога */
/*******************************************************************/
//Объявляем переменные
var FSO, F, SubFolders;
//Создаем объект FileSystemObject
FSO=WScript.CreateObject("Scripting.FileSystemObject");
//Создаем объект Folder для каталога C:\Program Files
F=FSO.GetFolder("C:\\Program Files");
//Создаем коллекцию подкаталогов каталога C:\Program Files
SubFolders=F.SubFolders;
// Создаем каталог C:\Program Files\Новая папка
Читать дальше