忍者ブログ

Home

溺れる者はUWSCを掴め!

[PR]

  • 2025-01-22 (Wed)
×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

  • Comments (Close):

UWSCで正規表現を使う

  • 2011-12-31 (Sat)
  • 実用スクリプト

UWSCで正規表現を使う場合にはVBScript又はJScriptを使うことにになるのですが、UWSCから使うならVBScriptの方が扱い安いですかね。

という事で今回はVBScriptのRegExpを使ったサンプル

正規表現のパターンの書方に関しては詳しく説明しないので各自ご確認を

RegExpのプロパティには以下のプロパティがあります。
Patternプロパティ 正規表現で使用するパターン
IgnoreCaseプロパティ 大文字と小文字を区別する(デフォルト:False)
Globalプロパティ 文字列全体を検索する(デフォルト:False)
RegExpのメソッドには以下のメソッドがあります。
Executeメソッド Patternとマッチした結果をMatchesコレクションで返します。
Replaceメソッド Patternとマッチした結果をを置換文字列と置き換えます。
Testメソッド Patternとマッチした場合はTrueを返します。

Executeメソッドのサンプル

PUBLIC regvb = CreateOLEObj("VBScript.RegExp")

   //--sample
   //str="2012年1月1日~2012年1月30日"
   //Pattern="\d+年(\d+月\d+日)"
   //
   //Matches=regvb_Execute(str,Pattern)
   //for i=0 to Matches.Count-1
   //   Print Matches.item(i).Value
   //   Print Matches.item(i).SubMatches(0)
   //   Print Matches.item(i).FirstIndex
   //   Print Matches.item(i).Length
   //next
   
//--
Function regvb_Execute(str,Pattern,IgnoreCase=true,Global=true)
   regvb.IgnoreCase = IgnoreCase
   regvb.Global = Global
   regvb.Pattern=Pattern
   Matches = regvb.Execute(str)
   Result=Matches
Fend
Executeメソッドを実行して帰ってくる戻値Matchesコレクションは以下のプロパティがあります。
Countプロパティ Matchオブジェクトの個数
Itemプロパティ MatchオブジェクトをMatches.Item(数字)で返す
Matchオブジェクト(=Matches.Item(数字))には以下のプロパティとコレクションがあります。
Valueプロパティ マッチした文字列を返す。
Lengthプロパティ マッチした文字列の長さを返す。
FirstIndexプロパティ 最初にマッチに成功した位置を返す。先頭は0から。
SubMatchesコレクション 「()で括られた」パターングループにマッチしたコレクションを返す。

sampleを実行すると以下の結果になる

---------結果-------
2012年1月1日
1月1日
0
9
2012年1月30日
1月30日
10
10
------------------------

最初にマッチしたのは「2012年1月1日」でSubMatches(0)は「1月1日」文字位置は「0」で文字列の長さは9文字


Replaceメソッドのサンプル

PUBLIC regvb = CreateOLEObj("VBScript.RegExp")

	//--sample
	//str="2012年1月1日~2012年1月30日"
	//Pattern="\d+年"
	//Print regvb_Replace(str,Pattern,"2013年")

//--
Function regvb_Replace(str,Pattern,replStr,IgnoreCase=true,Global=true)	
	regvb.IgnoreCase = IgnoreCase
	regvb.Global = Global
	regvb.Pattern=Pattern
	str = regvb.Replace(str,replStr)
	Result=str
Fend

sampleを実行すると以下の結果になる

---------結果-------
2013年1月1日~2013年1月30日
------------------------


TestメソッドはMatches.countが0だと失敗、0以上だと成功という風にExecuteで代用できるので省略します。

UWSCでsleipnirを使う上での基本とコツ

  • 2011-12-20 (Tue)
  • 覚えとくと役立つ知識

※記事内容はsleipnir2についての記事です

環境設定

ツール→sleipnirオプション→全般→「スクリプトによるクライアントの操作を許可する」にチェック

OLEオブジェクト作成とアクティブなタブの取得

pnir=CreateOLEobj("Sleipnir.API")
tab=pnir.ActiveIndex            //アクティブなタブのタブ位置
id=pnir.GetDocumentID(tab)        //タブのID
tab_obj= pnir.GetWebBrowserObject(id)  //タブのWebBrowserオブジェクト

短縮すると・・

pnir=CreateOLEobj("Sleipnir.API")
tab_obj= pnir.GetWebBrowserObject(pnir.GetDocumentID(pnir.ActiveIndex))

この戻り値tab_objは

IE=CreateOLEObj("InternetExplorer.Application")

で作成される戻り値IEとほぼ同等

なので

pnir=CreateOLEobj("Sleipnir.API")
IE=pnir.GetWebBrowserObject(pnir.GetDocumentID(pnir.ActiveIndex))

として戻り値をIEとしてしまった方がIE用に作ったFunction等が流用できるので便利

例えば・・
こんな風に使える

ifb Msgbox("IE場合はYes、pnirの場合はNo",BTN_YES or BTN_NO)=BTN_YES
	IE=CreateOLEObj("InternetExplorer.Application")
	IE.Visible=true
else
	pnir=CreateOLEobj("Sleipnir.API")
	IE=pnir.GetWebBrowserObject(pnir.GetDocumentID(pnir.ActiveIndex))
endif

IE.Navigate("http://www.yahoo.co.jp/")
BusyWait(IE)
doc=IE.document
Msgbox(doc.url)
//------
Procedure BusyWait(IE)
	Const TIME_OUT = 90
	tm = Gettime()
	repeat
		Sleep(0.2)
		ifb Gettime() - tm > TIME_OUT
			MsgBox("Time Out:BusyWait")
			ExitExit
		endif
	until (! ie.busy) and (ie.readyState=4)
	Sleep(0.5)
Fend

できないのはIE.Navigate2で新規タブを開く操作 IE.quitで閉じる操作ぐらいでほぼIEと同等の操作ができる。

Sleipnir特有の操作

詳しくは公式リファレンス見て欲しいんですが主な操作をいくつか

タブブラウザ Sleipnir オンラインデータベース(Sleipnir.API リファレンス)

新規タブを開く

id=pnir.newwindow(URL,true) 

trueで新規タブをアクティブにする

例)IE=pnir.GetWebBrowserObject(pnir.newwindow(URL,true))

開いてるタブの数

pnir.GetCount

タブを閉じる

pnir.Close(id)

IE・sleipnir・Firefox・chrome・Excel 2010のショートカット一覧ページのまとめ

  • 2011-12-10 (Sat)
  • 覚えとくと役立つ知識

Home

Search
Meta
Links
Feeds
PR
PR

Page Top