Web ページの html コンテンツを取得し、テーブルのコンテンツをスクレイピングする Perl スクリプトを作成したいと思います。正確なページは次のとおりです。
http://djbpmstudio.com/Default.aspx?Page=album&id=1
これまでのところ、次のコードを使用して、アーティスト、アルバム、ジャンル、およびテーブルの最初のエントリを正規表現できます。
use LWP::Simple;
$url = "http://djbpmstudio.com/Default.aspx?Page=album&id=1";
my $mystring = get($url) or die "Error fetching source page.";
$mystring =~ s/[\r\n]/ /g; #remove line breaks from HTML
$mystring =~ s/(>)\s+(<)/$1$2/g; #Remove white space between html tags
#print $mystring;
if($mystring =~ m{</table><h1>(.*?) - (.*?) - (.*?)</h1>}) {
#Get Artist name and print
print "Artist: $1\n";
print "Album: $2\n";
print "Genre: $3\n\n";
if($mystring =~ m{</tr><tr class="row-(.*?)"><td>(.*?)</td><td align="right">(.*?)</td></tr>}) {
#Get Songname and BPM and print
#print "$1\t";
print "$2\t";
print "$3\n";
}
}
ネストされた IF では、クラスは「row-a」と「row-b」を交互に繰り返します。
リストを下に移動して、それぞれの曲名と BPM をすべて取得する方法がわかりません。また、曲名と BPM を後で処理するために配列に入れたいと思います。
ありがとうございました。