我正在从Twitter api中搜索,使用file_get_contents获取数据,然后传递给json_decode,这给了我这个数组结构。
{"results":[
{
"from_user":"A-user-name",
"from_user_id":457304735,
"text":"Ich R U #BoysNoize #SuperRola",
"entities":{
"urls":[{
"url":"http:\/\/t.co\/WZnUf68j",
"expanded_url":"http:\/\/instagr.am\/p\/Vz4Nnbnjd6\/",
}]
}]
]
对于每个推送的推文重复这一步骤,现在我可以使用foreach循环访问用户名和文本,并将每个结果实例分配给变量,然后从变量中提取数据。
foreach($jsonArr['results'] as $item){
// Takes the Array jsonArr and for every results heading creates an $item
$user = mysql_real_escape_string($item['from_user']);
$text = mysql_real_escape_string($item['text']);
这样可以保存正确的变量OK,但我似乎无法在结果中获取实体数组中的数据。如果我打印出实体var,如我得到的用户名或文字
ArrayArrayArrayArrayArrayArrayArrayArrayArrayArray
所以它保留了返回的每个结果的数组,但我到底如何访问它,我一直在搞乱我知道的一些其他方法来访问数组数据,但它们似乎都没有。任何有关如何获得这些值的帮助,或者将它们与foreach集成在一起都将非常感激
答案 0 :(得分:4)
假设您选择将JSON解码为多维数组而不是对象:
foreach ($results as $tweet) {
$user = $tweet["from-user"];
$text = $tweet["text"];
$entities = $tweet["enities"];
$urls = $entities["urls"];
foreach ($urls as $url) {
echo $url["expanded_url"];
}
}
等等
答案 1 :(得分:4)
Array
(
[results] => Array
(
[0] => stdClass Object
(
[entities] => Array
(
[0] => stdClass Object
(
[urls] => Array
(
[0] => stdClass Object
(
[expanded_url] => http://instagr.am/p/Vz4Nnbnjd6/
[url] => http://t.co/WZnUf68j
)
)
)
)
[from_user] => A-user-name
[from_user_id] => 457304735
[text] => Ich R U #BoysNoize #SuperRola
)
)
)
访问网址:
$json_array['results'][0]->entities[0]->urls[0]->url;
有用的代码:
<?php
$json ='{ "results" : [ { "entities" :
[ { "urls" : [ { "expanded_url" : "http://instagr.am/p/Vz4Nnbnjd6/",
"url" : "http://t.co/WZnUf68j"
} ] } ],
"from_user" : "A-user-name",
"from_user_id" : 457304735,
"text" : "Ich R U #BoysNoize #SuperRola"
} ] }';
$json_array = (array)(json_decode($json));
echo '<pre>';
//print_r($json_array);
echo $json_array['results'][0]->entities[0]->urls[0]->url;
&GT;
答案 2 :(得分:1)
只需做一个print_r($jsonArr);
,您就可以使用已解码的json。