<?xml version="1.0" encoding="Shift_JIS" standalone="yes" ?> <package> <job> <script language="JScript"><![CDATA[ var shell = new ActiveXObject ("WScript.Shell"); shell.Run ("cscript //Job:EntryJob \"" + WScript.ScriptFullName + "\"", 1, false); ]]></script> </job> <job id="EntryJob"> <script language="JScript"><![CDATA[ WScript.Echo ("Hello world !"); WScript.StdIn.ReadLine (); ]]></script> </job> </package>実際に実行したい処理は EntryJob の部分です。デフォルトで実行されるジョブ内で、ジョブを指定して自分自身を呼び出しています。
.NET Frameworkのバージョンを確認する方法を参考に WSH スクリプトを書いた。
拡張子を .wsf で保存して実行してくださいねー。
<?xml version="1.0" encoding="Shift_JIS" standalone="yes" ?> <package> <job id="Registry"> <?job error="True" debug="True" ?> <script language="JScript"> <![CDATA[ var checker = new DotNetChecker (); var result = ""; result += checker.FormatResult (checker.Check10 (), ".NET Framework 1.0"); result += checker.FormatResult (checker.Check11 (), ".NET Framework 1.1"); result += checker.FormatResult (checker.Check11JP (), " Japanese Langage Pack"); result += checker.FormatResult (checker.Check20 (), ".NET Framework 2.0"); result += checker.FormatResult (checker.Check20JP (), " Japanese Langage Pack"); result += checker.FormatResult (checker.Check30 (), ".NET Framework 3.0"); result += checker.FormatResult (checker.Check30JP (), " Japanese Langage Pack"); result += checker.FormatResult (checker.Check35 (), ".NET Framework 3.5"); result += checker.FormatResult (checker.Check35JP (), " Japanese Langage Pack"); WScript.Echo (result); function DotNetChecker () { this.reader = new RegReader (); this.Check10 = function () { var install = this.reader.RegRead ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\Full\\v1.0.3705\\1041\\Microsoft .NET Framework Full v1.0.3705 (1041)\\Install"); if (install == null || "" + install == "0") return null; var version = this.reader.RegRead ("HKLM\\SOFTWARE\\Microsoft\\Active Setup\\Installed Components\\{78705f0d-e8db-4b2d-8193-982bdda15ecd}\\Version"); if (version == null) version = this.reader.RegRead ("HKLM\\SOFTWARE\\Microsoft\\Active Setup\\Installed Components\\{FDC11A6F-17D1-48f9-9EA3-9051954BAA24}\\Version"); if (version == null) return 0; var regex = /^1,0,3705,(\d+)$/; var m = regex.exec (version); var sp = 0; if (m != null && m.length > 1) sp = m [1] - 0; return sp; } this.Check11 = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v1.1.4322"); } this.Check20 = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v2.0.50727"); } this.Check30 = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v3.0"); } this.Check35 = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v3.5"); } this.Check11JP = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v1.1.4322\\1041"); } this.Check20JP = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v2.0.50727\\1041"); } this.Check30JP = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v3.0\\1041"); } this.Check35JP = function () { return this.CheckKey ("HKLM\\SOFTWARE\\Microsoft\\NET Framework Setup\\NDP\\v3.5\\1041"); } this.CheckKey = function (key) { var install = this.reader.RegRead (key + "\\Install"); if (install == null || "" + install == "0") return null; var sp = this.reader.RegRead (key + "\\SP"); if (sp == null) sp = 0; return sp; } this.FormatResult = function (value, label) { var result = label; switch (value) { case null: result += ": not installed.\n"; break; case 0: result += ": installed.\n"; break; default: result += ": SP" + value + " installed.\n"; break; } return result; } } function RegReader () { this.shell = WScript.CreateObject ('WScript.Shell'); this.RegRead = function (name) { var ret = null; try { ret = this.shell.RegRead (name); } catch (e) { //WScript.Echo (e.number + "\n" + e.description); } return ret; } return this; } ]]> </script> </job> </package>
拡張子 .wsf のファイルでは、XMLをちょろっと書くだけで Usage (使用方法) が生成できます。
<?xml version="1.0" encoding="utf-8"?>
<package>
<job>
<runtime>
<description>サンプルスクリプトです。</description>
<named
name="A"
helpstring="名前つき引数Aです"
type="string"
required="true"/>
<named
name="B"
helpstring="名前つき引数Bです"
type="boolean"
required="false"/>
<named
name="C"
helpstring="名前つき引数Cです"
type="simple"
required="false"/>
<unnamed
name="arga"
helpstring="名前なし引数Aです"
many="false"
required="true"/>
<unnamed
name="argb"
helpstring="名前なし引数Bです"
many="true"
required="false"/>
<example></example>
</runtime>
<script language="JScript"><![CDATA[
WScript.Arguments.ShowUsage ();
]]></script>
</job>
</package>
>cscript test.wsf /? Microsoft (R) Windows Script Host Version 5.6 Copyright (C) Microsoft Corporation 1996-2001. All rights reserved. サンプルスクリプトです。 使い方 : test.wsf /A:値 [/B[+|-]] [/C] arga [argb1 argb2...] オプション : A : 名前つき引数Aです B : 名前つき引数Bです C : 名前つき引数Cです arga : 名前なし引数Aです argb : 名前なし引数Bです
サンプルの script 要素内にもありますが WScript.Arguments.ShowUsage (); でプログラム内から表示させることもできるので、引数が不正な時などにも使えそうです。
// // makeZipFolder.js // // スクリプト ランタイム関連 var fileSystemObject = new ActiveXObject ('Scripting.FileSystemObject'); var wsShell = new ActiveXObject ('WScript.Shell'); // 固めるパス var sourcePath = wsShell.SpecialFolders ('AppData'); sourcePath = fileSystemObject.BuildPath (sourcePath, "Test"); // デスクトップ var desktopPath = wsShell.SpecialFolders ('Desktop'); // 作成する ZIP ファイルのパス var zipPath = fileSystemobject.BuildPath (desktopPath, 'Test.zip'); // ZIP ファイルを作成する var zipFile = fileSystemObject.CreateTextFile (zipPath, false); zipFile.Write ("PK\5\6\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"); zipFile.Close (); // ZIP ファイルを圧縮フォルダとして取得 var shell = new ActiveXObject ('Shell.Application'); var zipFolder = shell.NameSpace (zipPath); // コピー元 var sourceFolder = fileSystemObject.GetFolder (sourcePath); for (var n = 0, var e = new Enumerator (sourceFolder.Files); ! e.atEnd (); e.moveNext ()) { // ファイルをコピー var sourceFolderItem = shell.Namespace (e.item ().ParentFolder.Path).ParseName (e.item ().Name); zipFolder.CopyHere (sourceFolderItem); n ++; // コピーが完全に完了するまで待機 while (n == zipFolder.Items ().Count) { WScript.Sleep (100); } } WScript.echo ("完了しました。");
// // enumIme.js // // 定義済み HKEY var HKEY_CLASSES_ROOT = 0x80000000; var HKEY_CURRENT_USER = 0x80000001; var HKEY_LOCAL_MACHINE = 0x80000002; var HKEY_USERS = 0x80000003; var HKEY_CURRENT_CONFIG = 0x80000005; var HKEY_DYN_DATA = 0x80000006; // WMI の StdRegProv を使用する var locator = new ActiveXObject ("WbemScripting.SWbemLocator"); var service = locator.ConnectServer (null, "root\\default"); var stdRegProv = service.Get ("StdRegProv"); // スクリプト ランタイム関連 var fileSystemObject = new ActiveXObject ('Scripting.FileSystemObject'); var wsShell = new ActiveXObject ('WScript.Shell'); var desktopPath = wsShell.SpecialFolders ('Desktop'); // ログファイル、Layout Text 等が SJIS では表示できない可能性があるため、ユニコードテキストで var logFile = fileSystemObject.CreateTextFile (fileSystemObject.BuildPath (desktopPath, "imecheck.txt"), true, true); // すべてのキーボードレイアウト // HKLM\SYSTEM\CurrentControlSet\Control\Keyboard Layouts var lmImeList = new SubKey (stdRegProv, HKEY_LOCAL_MACHINE, "SYSTEM\\CurrentControlSet\\Control", "Keyboard Layouts"); lmImeList.getSubKeys (); // 言語バーより選択可能なキーボードレイアウト // HKCU\Keyboard Layout\Preload var preload = new SubKey (stdRegProv, HKEY_CURRENT_USER, "Keyboard Layout", "Preload"); for (var item in preload.getRegValues ()) { logFile.Write (item); // 値名は番号 logFile.Write (":"); // 値はキーボードレイアウトの番号 logFile.WriteLine (preload.regValues [item].value); // キーボードレイアウトの番号より、情報を取り出す var keyObj = lmImeList.subKeys [preload.regValues [item].value.toUpperCase ()]; if (keyObj == null) keyObj = lmImeList.subKeys [preload.regValues [item].value.toLowerCase ()]; // 情報あり if (keyObj != null) { for (var item2 in keyObj.getRegValues ()) { // 値名 "layout text" を探す if (-1 != item2.search (/layout text/i)) {// 見つかった logFile.Write (" "); logFile.Write (item2); logFile.Write ("(" + keyObj.regValues [item2].typeName + ")"); logFile.Write ("\t:"); logFile.WriteLine (keyObj.regValues [item2].value); } } } } logFile.WriteBlankLine (); // Keyboard Layouts のリスト logFile.WriteLine (lmImeList.path); writeImeList (logFile, lmImeList, ""); // ファイルを閉じる logFile.Close (); // 終了 WScript.echo ("完了しました"); // // キーボードレイアウトのリストを出力する // function writeImeList (file, keyObj, padding) { var item; var pad = padding + " "; for (item in keyObj.getSubKeys ()) { file.WriteLine (pad + keyObj.subKeys[item].name); writeImeList (file, keyObj.subKeys[item], pad); } for (item in keyObj.getRegValues ()) { file.Write (pad); file.Write (item); file.Write ("(" + keyObj.regValues[item].typeName + ")"); file.Write ("\t:"); file.WriteLine (keyObj.regValues[item].value); } file.WriteLine (); } // レジストリキーオブジェクトのコンストラクタ function SubKey (regProv, hDefKey, parentSubKey, name) { // // メンバの初期化 // this.regProv = regProv; this.hDefKey = hDefKey; this.parentSubKey = parentSubKey; this.name = name; this.path = parentSubKey + "\\" + name; this.subKeys = null; this.regValues = null; // // メソッドの定義 // // サブキーのコレクションを取得 this.getSubKeys = function () { if (!this.subKeys) { var method = this.regProv.Methods_.Item ("EnumKey"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = this.hDefKey; inParameter.sSubKeyName = this.path; var outParameter = this.regProv.ExecMethod_ (method.Name, inParameter); this.subKeys = new Array (); if (outParameter.sNames != null) { var subKeys = outParameter.sNames.toArray (); for (var i = 0; i < subKeys.length; i ++) { this.subKeys [subKeys [i]] = new SubKey (this.regProv, this.hDefKey, this.path, subKeys [i]); } } } return this.subKeys; } // キー内の値の取得 this.getRegValues = function () { if (!this.regValues) { var method = this.regProv.Methods_.Item ("EnumValues"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = this.hDefKey; inParameter.sSubKeyName = this.path; var outParameter = this.regProv.ExecMethod_ (method.Name, inParameter); this.regValues = new Array (); if (outParameter.sNames != null) { var names = outParameter.sNames.toArray (); var types = outParameter.Types.toArray (); var typeNames = new Array ( "" , // 0 "REG_SZ" , // 1 "REG_EXPAND_SZ" , // 2 "REG_BINARY" , // 3 "REG_DWORD" , // 4 "REG_DWORD_BIG_ENDIAN" , // 5 "REG_LINK" , // 6 "REG_MULTI_SZ" , // 7 "REG_RESOURCE_LIST" , // 8 "REG_FULL_RESOURCE_DESCRIPTOR" , // 9 "REG_RESOURCE_REQUIREMENTS_LIST", // 10 "REG_QWORD" ); // 11 var getTypeValues = new Array ( null, getStringValue, getExpandedStringValue, getBinaryValue, getDWORDValue, getDWORDValue, null, getMultiStringValue, null, null, null, getQWORDValue); for (var i = 0; i < names.length; i ++) { this.regValues [names [i]] = new Object (); this.regValues [names [i]].name = names [i]; this.regValues [names [i]].type = types [i]; this.regValues [names [i]].typeName = typeNames [types [i]]; this.regValues [names [i]].value = ""; var fn = getTypeValues [types [i]]; if (fn) { this.regValues [names [i]].value = fn (this.regProv, this.hDefKey, this.path, names [i]); } } } } return this.regValues; } return this; } // 文字列値取得 function getStringValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetStringValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); return outParameter.sValue; } // 展開済み文字列値取得 function getExpandedStringValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetExpandedStringValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); return outParameter.sValue; } // バイナリ値取得 function getBinaryValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetBinaryValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); var str = ""; var ary = outParameter.uValue.toArray (); for (var i = 0; i < ary.length; i ++) { str += ary [i].toString (16) + ((i + 1) % 8)? " ": "\n"; } return str; } // DWORD 値取得 function getDWORDValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetDWORDValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); return outParameter.uValue.toString (16); } // QWORD 値取得 function getQWORDValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetQWORDValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); return outParameter.uValue.toString (16); } // マルチ文字列値取得 function getMultiStringValue (regProv, hDefKey, sSubKeyName, sValueName) { var method = regProv.Methods_.Item ("GetMultiStringValue"); var inParameter = method.InParameters.SpawnInstance_ (); inParameter.hDefKey = hDefKey; inParameter.sSubKeyName = sSubKeyName; inParameter.sValueName = sValueName; var outParameter = regProv.ExecMethod_ (method.Name, inParameter); return outParameter.sValue.toArray ().toString (); }
WSH よりクリップボードにアクセスすることはできない。しかし、調べてみたところ、Internet Explorer がクリップボードにアクセスするためのインターフェースを公開していることがわかった(常套手段?)。
そんなわけで、文字列をコピー & 取得する部分をクラス化した。
使い方はこんな感じで。
var clipboard = new Clipboard (); var s = clipboard.getText (); WScript.Echo (s); clipboard.setText (s.replace (/my/gi, "Your"));
WSH でショートカットを作成する方法です。どこにでも転がっているものと同じですが、自分のために。 コマンドラインコピーツール のインストーラとして作成したものです。
ASP のテストで、同時最大セッション数を超えるとエラー表示する、みたいな項目があったが、最大セッション数分手でブラウザを起動するのが面倒だった。セッション数だけ稼げれば別にブラウザは何でも良かったので、IE でいいやって WSH スクリプトを作成。
// NavMaxSess.js
var MAX_SESSION = 100;
for ( var i = 0; i < MAX_SESSION; i++ ) {
var oIE = WScript.CreateObject( "InternetExplorer.Application" );
oIE.Visible = true;
oIE.Navigate2( "http://aspserver/target.asp" );
}
小品ですが、結構重宝してます。
連番フォルダ作成バッチの姉妹品。WSHさえ入っていれば動くので、拡張機能を使いまくったBATファイルより汎用的なのかも。
MSDEのデータを手軽にExport/ImportするWSHスクリプトです。'.js'拡張子をつけて保存し、ダブルクリックするかコンソールからCSCRIPT Export.jsなどとして実行します。わざわざ実行速度の遅いJScriptで作っている理由は、単に try{...} catch( e ) {...} でトランザクション処理がしたかったというだけのことです 笑。
MSDE用になっているのは接続文字列だけなので、その部分のみ変更すればOracleやJETなど、ADOで接続可能なDBであれば使用可能だと思います。(でもWSHが利用可能な環境でしか実行できません。)