スポンサーサイト

上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。

アニメ番組表取得ソフト その2

悪い予感が当たってしまいました。
the.tvが(多分)4月1日にリニューアルしたため、これまで通りの動作をしなくなってしまいました。

これまで、従来のソフトの仕様で一気に1週間分の番組表が取得できたのですが、リニューアル以後1日分の番組表しか取得できなくなってしまいました。

仕方がないので、ループで1週間分取得するように書き直しました。

が、SmallBasicの時間関数が弱すぎる(泣)
現在の日時を取得する関数しか無いのよね。
しかも文字列。(YYYY/MM/DD形式)

つまり、翌日の日付を取得したい場合、単純に現在の日付に"1"プラスできないので、月や年をまたぐ際にはそれなりの文字列処理をしなくてはならず、「大の月、小の月の判別」「2月は28日」さらに「うるう年」まで考えると、もううんざり。

そんな事態になるまでには、またリニューアルするだろうってコトで、大いなる妥協をすることにしました。
と言うことで、月末の1週間は誤動作します(キリッ)

お金貰うソフトだったらそこらへんキッチリ書きますけど、俺用だから(笑)

実行形式はこちら(thetv_anime_2.zip)

ソースリストは以下。
例によって小文字。



main()
Program.End()

Sub main
init()

today()
day = Stack.PopValue( "today" )
TextWindow.WriteLine( day )

fp = "thetv.txt"
File.WriteContents( fp, "" )

For i = 0 to 6
File.AppendContents( fp, "アニメ" + CRLF )
anime = "http://thetv.jp/program/schedule/list/anime/terrestrial/" + day + "/page:"
Stack.PushValue( "getbangumi", anime )
getBangumi()

'http://thetv.jp/program/schedule/list/drama/terrestrial/
'http://thetv.jp/program/schedule/list/variety/terrestrial/
'http://thetv.jp/program/schedule/list/movie/terrestrial/
'http://thetv.jp/program/schedule/list/sports/terrestrial/
'http://thetv.jp/program/schedule/list/documentary/terrestrial/
'http://thetv.jp/program/schedule/list/other/terrestrial/

date = Text.GetSubTextToEnd( day, 7 ) + 1
day = Text.GetSubText( day, 1, 6 )
If( Text.GetLength( date ) = 1 )Then
date = Text.Append( "0" , date )
EndIf
day = Text.Append( day , date )

EndFor

TextWindow.WriteLine( "end" )
EndSub

'get html & write file
'IN : URL
'OUT : ---
Sub getBangumi
gb_bangumi = Stack.PopValue( "getbangumi" )

For gb_i = 1 To 30
gb_web[gb_i] = Network.GetWebPageContents( gb_bangumi + gb_i )
While( Text.IsSubText( gb_web[gb_i], "title_bangumi" ))

Stack.PushValue( "getTitle", gb_web[gb_i] )
getTitle()
gb_web[gb_i] = Stack.PopValue( "getTitle" ) 'web HTML
gb_text = Stack.PopValue( "getTitle" ) 'text
gb_date = Stack.PopValue( "getTitle" ) 'date,time,ch
gb_title = Stack.PopValue( "getTitle" ) 'title

TextWindow.WriteLine( gb_date + HT + gb_title + HT + HT + gb_text )
File.AppendContents( fp, gb_date + HT + gb_title + HT + HT + gb_text )
' TextWindow.WriteLine( Text.GetSubText( web[1], 1, 100 ))
EndWhile
TextWindow.WriteLine( CRLF + "---------- Page : " + gb_i + "---------- " + CRLF )
File.AppendContents( fp, CRLF + "---------- Page : " + gb_i + "---------- " + CRLF )

If( Text.IsSubText( gb_web[gb_i], "next disabled" ) Or Text.IsSubText( gb_web[gb_i], PAGER ) = "False" )Then
Goto break
endIf
Endfor

break:
EndSub

'remove html_tag
'IN : web HTML
'OUT : 1=HTML 2=date,time,ch 3=title, 4=text
Sub getTitle
gt_web = Stack.PopValue( "getTitle" )

gt_web = Text.GetSubTextToEnd( gt_web, Text.GetIndexOf( gt_web, "title_bangumi" )+15 )
gt_stPos = Text.GetIndexOf( gt_web, ">" )+1
gt_edPos = Text.GetIndexOf( gt_web, "</p>" )
If( gt_stPos > gt_edPos )Then
gt_stPos =1
EndIf
gt_len = gt_edPos - gt_stPos
Stack.PushValue( "getTitle", Text.GetSubText( gt_web, gt_stPos, gt_len ) )

gt_web = Text.GetSubTextToEnd( gt_web, Text.GetIndexOf( gt_web, "time_bangumi" ) )
gt_stPos = Text.GetIndexOf( gt_web, ">" )+1
gt_edPos = Text.GetIndexOf( gt_web, "<br" )
gt_len = gt_edPos - gt_stPos
gt_date = Text.GetSubText( gt_web, gt_stPos, gt_len ) 'date

gt_stPos = Text.GetIndexOf( gt_web, "<br" )+6
gt_edPos = Text.GetIndexOf( gt_web, "</p>" )
gt_len = gt_edPos - gt_stPos
gt_time = Text.GetSubText( gt_web, gt_stPos, gt_len ) 'time,ch
Stack.PushValue( "getTitle", gt_date + HT + gt_time + " " )

gt_web = Text.GetSubTextToEnd( gt_web, Text.GetIndexOf( gt_web, TXT )-2 )
gt_stPos = Text.GetIndexOf( gt_web, TXT )+16
gt_edPos = Text.GetIndexOf( gt_web, "</p>" )
gt_len = gt_edPos - gt_stPos
gt_text = Text.GetSubText( gt_web, gt_stPos, gt_len ) 'text
Stack.PushValue( "getTitle", gt_text )

Stack.PushValue( "getTitle", gt_web )
EndSub

'get today
'IN : ---
'OUT : date(YYYYMMDD)
Sub today
today_d = Clock.Date
today_day = Text.GetSubText( today_d, 1, 4 ) 'YYYY
today_day = Text.Append( today_day, Text.GetSubText( today_d, 6, 2 ) ) 'MM
today_day = Text.Append( today_day, Text.GetSubText( today_d, 9, 2 ) ) 'DD
TextWindow.Write( "YYYYMMDD(" + today_day + ")" )
today_d = TextWindow.ReadNumber()
If( today_d <> 0 ) Then
today_day = today_d
EndIf
Stack.PushValue( "today", today_day )
EndSub

'set global
Sub init
CRLF = Text.GetCharacter(13) + Text.GetCharacter(10)
HT = Text.GetCharacter(9)
DQ = Text.GetCharacter(34) 'double quatation
PAGER = "class=" + DQ + "pager" + DQ
TXT = "<p class=" + DQ +"text" + DQ + ">"
EndSub
スポンサーサイト
プロフィール

toshi_tagiya

Author:toshi_tagiya
(資)田木屋商店
ソフトウェア開発室


(資)田木屋商店 TopPage
(資)田木屋商店 SoftWare
toshi's page

最新記事
最新コメント
最新トラックバック
月別アーカイブ
カテゴリ
検索フォーム
RSSリンクの表示
リンク
ブロとも申請フォーム

この人とブロともになる

QRコード
QR
上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。