( [VBScript] 世界へ発信!英語術をバックアップする > Z_ ̄∂
どーもボキです。

[VBScript] ニュースで英会話をバックアップするを改良して、新番組である「世界へ発信!英語術」に対応させた。

必要な準備は、前回の記事を参考に。
UWSCの設定 > 指定ウィンドウ名を「 - 世界へ発信!英語術 - 」へ変更すること。

a0021757_11121905.png
実行イメージ

SetScriptHost("CScript")

Set objWS = CreateObject("WScript.Shell")
Set objFS = CreateObject("Scripting.FileSystemObject")

' 18.04.01~実行日までをループさせる
y0 = 2018
y1 = Year(Now)

If y1 = y0 Then
m0 = 4
m1 = Month(Now)
Else
m0 = 1
m1 = 12
End If

d0 = 1
If m0 = m1 Then
d1 = Day(Now)
Else
d1 = 31
End If

Arr_url = Array("s", "k", "w")
Arr_key = Array("_センテンス", "_キーワード", "_ボキャブラリー")

DPath = objWS.SpecialFolders("MyDocuments") &"\"
For yyyy = y0 To y1
For mm = m0 To m1
If Len(mm) = 1 Then mm = "
0" & mm
For dd = d0 To d1: Do
If Len(dd) = 1 Then dd = "
0" & dd

r = -1
On Error Resume Next
r = Weekday(yyyy &"
/" & mm & "/" & dd)
On Error GoTo 0
If (r < vbMonday) Or (r > vbFriday) Then Exit Do

' 保存フォルダ作成
DPath_Save = DPath & Right(yyyy,2) & mm &"
\"
If Not objFS.FolderExists(DPath_Save) Then objFS.CreateFolder(DPath_Save)

' 保存済みmp3のサイズチェック
yymmdd = Right(yyyy,2) & mm & dd
fname = SearchFile(DPath_Save, yymmdd & "
*.mp3")
If fname <> "
" Then
Set fmp3 = objFS.GetFile(DPath_Save & fname)
If fmp3.Size <> 0 Then Exit Do ' 保存済み
End If

' 本文テキスト&音声を録音
fname = ProcURL("
http://www.nhk.or.jp/snsenglish/news/n"& yymmdd &".html", DPath_Save, "")
If fname = "
" Then Exit Do ' 放送なし or アンコール放送

' 残りのテキストを保存
For i = 0 To UBound(Arr_url)
fname = SearchFile(DPath_Save, yymmdd & "
*" & Arr_key(i) & "*")
If fname = "
" Then
ProcURL "
http://www.nhk.or.jp/snsenglish/elearning/" & Arr_url(i) & yymmdd &".html", DPath_Save, fname & Arr_key(i)
End If
Next
Loop Until 1: Next
Next
Next
'===============================================================================
' URLを開く
' 戻り値:(番組が存在した場合)YYMMDD_タイトル
Function ProcURL(URL, FolderPath, PostFix)
Dim objWS: Set objWS = CreateObject("
WScript.Shell")
Dim i,s,key,fname,yymmdd,objIE,ieDoc

i = InStr(URL, "
.html")
yymmdd = Mid(URL, i-6,6) ' yymmddを取得

Do
Set objIE = CreateObject("
InternetExplorer.Application")
objIE.Navigate URL
Do While objIE.Busy: WScript.Sleep 1000: Loop ' ページ読み込み完了待ち

Set ieDoc = objIE.Document
s = ieDoc.Title
i = InStr(s,"
- 世界へ発信!英語術 - NHK") -1
If (i < 0) Or (InStr(s,"
アンコール放送") > 0) then Exit Do ' ⇒ 終了

fname = yymmdd &"
_"& Left(s,i)
If PostFix = "
" Then
dprintf fname

' VoiceRecorderの設定変更
rpth = "
HKCU\Software\Moo0\Moo0 VoiceRecorder\SaveData\MainWindow\CreationPath\"
key = rpth & "
FolderPath"
i = objWS.RegWrite(key, FolderPath, "
REG_SZ") ' 保存フォルダパス
key = rpth & "
FileName"
i = objWS.RegWrite(key, fname, "
REG_SZ") ' 保存ファイル名

' VoiceRecorder起動
objWS.Run "
"""& objWS.SpecialFolders("MyDocuments") &"\AudioRecorder 1.46\VoiceRecorder.exe"""
WScript.Sleep 1000
objWS.SendKeys "
^ " ' Rec Start
Do
objIE.Visible = True ' 再生(UWSC)
WScript.Sleep 10000
objIE.Visible = False
r = CreateObject("
WScript.Shell").PopUp("finish?",80,"now recording...",vbYesNo)
Loop Until (r = vbYes) Or (r = -1)
TerminateProcess("
VoiceRecorder.exe")
End If
' URLをmhtファイルで保存
On Error Resume Next
Set objCDO = CreateObject("
CDO.Message")
objCDO.CreateMHTMLBody(URL)
objCDO.BodyPart.GetStream.SaveToFile FolderPath & fname & PostFix & "
.mht", 2
Set objCDO = Nothing

Loop Until 1

objIE.Quit
Set objIE = Nothing

ProcURL = fname
End Function
'-------------------------------------------------------------------------------
' 指定したファイル名が存在するか調べる(ワイルドカードOK)
' 戻り値:見つかったファイル名
Function SearchFile(DirectoryPath, FileName)
Dim objFS,f,r,dpth

r = "
"
Set objFS = CreateObject("
Scripting.FileSystemObject")
On Error Resume Next
dpth = DirectoryPath & Year(Now) & Month(Now) & Day(Now) & Hour(Now) & Minute(Now) & Second(Now)
objFS.CreateFolder(dpth) ' 重複しないフォルダを作成
objFS.MoveFile DirectoryPath & FileName, dpth &"
\"
For Each f In objFS.GetFolder(dpth).Files
r = f.Name
Next
objFS.MoveFile dpth &"
\"& FileName, DirectoryPath
objFS.DeleteFolder dpth
On Error GoTo 0

SearchFile = r
End Function
' -------------------------------------------------------------------------------
' 指定した名前のプロセスを強制終了する
Sub TerminateProcess(ProcessName)
Dim objProcList,objProcess

Set objProcList = GetObject("
winmgmts:").InstancesOf("win32_process")
For Each objProcess In objProcList
If LCase(objProcess.Name) = LCase(ProcessName) Then
objProcess.Terminate
End If
Next
End Sub
' -------------------------------------------------------------------------------
' 実行ホストを切り替える
Sub SetScriptHost(HostName)
Dim i,s

If InStr(LCase(WSCript.FullName), LCase(HostName)) <> 0 Then Exit Sub

s = HostName & "
""" & WScript.ScriptFullName & """"
If WScript.Arguments.Count > 0 Then
For i = 0 To WScript.Arguments.Count -1
s = s &"
""" & WScript.Arguments.Item(i) & """" ' 引数
Next
End If
CreateObject("
WScript.Shell").Run s
WScript.Quit
End Sub
' -------------------------------------------------------------------------------
' デバッグ ※ここだけ抜粋してもOK
Dim objDbg
' クラス
Class TDebug
Dim FCScript

' 初期化処理
Private Sub Class_Initialize()
FCScript = InStr(LCase(WSCript.FullName), "
cscript") > 0
End Sub

' 終了処理
Private Sub Class_Terminate()
If Not FCScript Then Exit Sub

WScript.StdOut.WriteLine NOW & "
[END]"
WScript.StdIn.ReadLine
End Sub

' CScriptホストかどうか
Public Property Get CScript
CScript = FCScript
End Property

' デバッグメッセージ処理
Public Sub dprintf(v)
Dim i,s,ityp
If Not FCScript Then Exit Sub

s = v
ityp = VarType(v)
If ityp = vbBoolean Then
s = CStr(v)
ElseIf VarType(v) >= vbArray Then
s = "
"
For i = 0 to UBound(v)
s = s & "
dprintf(" &i& ")=" & v(i) & vbCRLF
Next
End If
WScript.Echo s
End Sub
End Class
' 関数
Sub dprintf(v)
If VarType(objDbg) = vbEmpty Then
Set objDbg = New TDebug
objDbg.dprintf(NOW & "
" & WScript.ScriptFullName)
End If
objDbg.dprintf(v)
End Sub
' -------------------------------------------------------------------------------

[PR]
by yozda | 2018-04-14 11:10 | プログラミング | Trackback | Comments(0)
トラックバックURL : https://yozda.exblog.jp/tb/238459976
トラックバックする(会員専用) [ヘルプ]
<< [VBScript] ワイルド... [VBScript] ニュース... >>