PHP (Rich Adams による php-gracenote) を使用して Gracenote API に接続し、さまざまなアルバム/CD に関するデータを取得しています。基本的な作業は完了しました。接続して、クエリを作成し、データを取得できますが、Gracenote が送信するデータの配列を操作する方法について混乱しています。
アルバム/CD を検索して、そのアルバムのトラックのリストを表示できるようにしたいです。
私が使用しているコードは次のとおりです。
<?php
include("php-gracenote/Gracenote.class.php");
$clientID = "XXXXXXX";
$clientTag = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX";
$api = new Gracenote\WebAPI\GracenoteWebAPI($clientID, $clientTag);
$userID = $api->register();
//$results = $api->searchAlbum("Beatles", "Revolver");
//var_dump($results);
$i=0;
while (isset($results[$i])) :
echo $results[$i]["album_artist_name"] . '<br/>';
echo $results[$i]["album_title"] . ', ' . $results[$i]["album_year"] . '<br/><br/>';
//echo $results[$i]["tracks"]["track_title"]; // my feeble attempt to grab relevant data
$i++;
endwhile;
?>
私が使用する場合:
$results = $api->searchAlbum("Beatles", "Revolver");
var_dump($results);
... データは大きな (多次元???) 配列として返されるようで、データのあちこちにトラック タイトルが表示されますが、それらを抽出して表示することはできません。
私の質問は、必要なデータを抽出するために PHP で複雑な配列を操作するにはどうすればよいかということだと思います。
var_dump($results) を使用したときに返されるデータの最初のセクションを次に示します。すべてを表示するには多すぎます)。
array(10) {
[0]=>
array(13) {
["album_gnid"]=>
string(40) "7309349-74C2EDC353EA348726D4EDC7B705712F"
["album_artist_name"]=>
string(11) "The Beatles"
["album_title"]=>
string(8) "Revolver"
["album_year"]=>
string(4) "1966"
["genre"]=>
array(3) {
[0]=>
array(2) {
["id"]=>
int(25313)
["text"]=>
string(4) "Rock"
}
[1]=>
array(2) {
["id"]=>
int(25332)
["text"]=>
string(9) "60's Rock"
}
[2]=>
array(2) {
["id"]=>
int(25491)
["text"]=>
string(16) "Psychedelic Rock"
}
}
["album_art_url"]=>
string(0) ""
["artist_image_url"]=>
string(99) "http://akamai-b.cdn.cddbp.net/cds/2.0/image-artist/0907/CA7C/7B5E/3CF8_medium_front.jpg?cid=1920256"
["artist_bio_url"]=>
string(164) "http://web.content.cddbp.net/cds/2.0?id=0AC9F1E7DEF84B87&client=1920256&class=biography&type=text/plain&tag=02-FAyNX5AA5SimoRYGji2zgKvh9LliCiQjTJOnammvNzcmKGySJQ-0g"
["review_url"]=>
string(161) "http://web.content.cddbp.net/cds/2.0?id=F4B46CE1824CDFF5&client=1920256&class=review&type=text/plain&tag=02jCWyg580ffijjOeNpgMYD-33vNd9OY0N72B5abMJa3FKUaP3bDIZcA"
["artist_origin"]=>
array(4) {
[0]=>
array(2) {
["id"]=>
int(29894)
["text"]=>
string(14) "Western Europe"
}
[1]=>
array(2) {
["id"]=>
int(29967)
["text"]=>
string(14) "United Kingdom"
}
[2]=>
array(2) {
["id"]=>
int(30296)
["text"]=>
string(7) "England"
}
[3]=>
array(2) {
["id"]=>
int(30793)
["text"]=>
string(9) "Liverpool"
}
}
["artist_era"]=>
array(1) {
[0]=>
array(2) {
["id"]=>
int(29487)
["text"]=>
string(6) "1960's"
}
}
["artist_type"]=>
array(2) {
[0]=>
array(2) {
["id"]=>
int(29422)
["text"]=>
string(4) "Male"
}
[1]=>
array(2) {
["id"]=>
int(29436)
["text"]=>
string(10) "Male Group"
}
}
["tracks"]=>
array(14) {
[0]=>
array(6) {
["track_number"]=>
int(1)
["track_gnid"]=>
string(40) "7309350-3A1042A706E8D9391D2728421B86C7BD"
["track_title"]=>
string(6) "Taxman"
["track_artist_name"]=>
string(11) "The Beatles"
["mood"]=>
array(0) {
}
["tempo"]=>
array(0) {
}
}
[1]=>
array(6) {
["track_number"]=>
int(2)
["track_gnid"]=>
string(40) "7309351-8D7A9A90FA399B346AA64396FA6C697A"
["track_title"]=>
string(13) "Eleanor Rigby"
["track_artist_name"]=>
string(11) "The Beatles"
["mood"]=>
array(0) {
}
["tempo"]=>
array(0) {
}
}
アドバイスをいただければ幸いです。