从 json/xml 返回数组创建下拉列表
Create drop down list from json/xml returned arrary
我正在尝试通过 food_id 和 food_name 从 Fatsecret REST API 返回的数组中创建一个下拉列表,但没有成功。
我的密码是
<?php
$base = rawurlencode("GET")."&";
$base .= "http%3A%2F%2Fplatform.fatsecret.com%2Frest%2Fserver.api&";
$params = "format=json&";
$params = "method=foods.search&";
$params .= "oauth_consumer_key=my key&";
$params .= "oauth_nonce=123&";
$params .= "oauth_signature_method=HMAC-SHA1&";
$params .= "oauth_timestamp=".time()."&";
$params .= "oauth_version=1.0&";
$params .= "search_expression=flour";
$params2 = rawurlencode($params);
$base .= $params2;
//encrypt it!
$sig= base64_encode(hash_hmac('sha1', $base, "4e0b6b00578b4a8995975b289879ae4e&", true));
$url = "http://platform.fatsecret.com/rest/server.api?".$params."&oauth_signature=".rawurlencode($sig);
返回的数组对象为
object(SimpleXMLElement)#555 (4) {
["max_results"]=> string(2) "20"
["total_results"]=> string(3) "186"
["page_number"]=> string(1) "0"
["food"]=> array(20) {
[0]=> object(SimpleXMLElement)#549 (5) {
["food_id"]=> string(4) "3419"
["food_name"]=> string(11) "White Flour"
["food_type"]=> string(7) "Generic"
["food_url"]=> string(63) "http://www.fatsecret.com/calories-nutrition/generic/flour-white"
["food_description"]=> string(75) "Per 100g - Calories: 364kcal | Fat: 0.98g | Carbs: 76.31g | Protein: 10.33g" }
[1]=> object(SimpleXMLElement)#554 (6) {
["food_id"]=> string(7) "1727595"
["food_name"]=> string(17) "All-Purpose Flour"
["brand_name"]=> string(10) "Gold Medal"
["food_type"]=> string(5) "Brand"
["food_url"]=> string(72) "http://www.fatsecret.com/calories-nutrition/gold-medal/all-purpose-flour"
["food_description"]=> string(77) "Per 1/4 cup - Calories: 100kcal | Fat: 0.00g | Carbs: 22.00g | Protein: 3.00g" }
[2]=> object(SimpleXMLElement)#553 (6) {
["food_id"]=> string(5) "56342"
["food_name"]=> string(17) "All Purpose Flour"
["brand_name"]=> string(7) "Wegmans"
["food_type"]=> string(5) "Brand"
["food_url"]=> string(69) "http://www.fatsecret.com/calories-nutrition/wegmans/all-purpose-flour"
["food_description"]=> string(78) "Per 1/4 cup - Calories: 100kcal | Fat: 0.00g | Carbs: 22.00g | Protein: 4.00g" }
此时我尝试了下面的代码
echo '<select>';
$jsonData = file_get_contents($url);
$jsonDataObject = json_decode($jsonData);
foreach($jsonDataObject->response->values as $option){
echo '<option value=' . $option->food_id . '>' . $option->food_name . '</option>';
}
echo '</select>';
但运气不好。
最终我尝试了
$food_feed = file_get_contents($url);
$food = simplexml_load_string($food_feed);
$obj_xml = simplexml_load_string($food_feed);
// Total number of elements present ///
$total = $obj_xml->count(); // total number of elements for PHP 5.3 and above
$str="<select name='student'>";
for($i=0; $i<$total; $i++) {
$str= $str . "<option value=".$obj_xml->food[$i]->food_id.">".$obj_xml->food[$i]->food_name. "</option>";
}
$str = $str. "</select>";
echo $str;
这段代码确实有效但是它在下拉列表的末尾添加了几个额外的空行,我找不到原因。
如果有人能帮助我找到实现目标的更好方法,我将不胜感激。
此致
好的,我已经设法解决了这个问题,以防万一这对某人有帮助。
$food 是一个 simplexml 对象,我们可以访问像
这样的元素
foreach( $food->{'[array]'} as $array_variable )
所以我们的循环会变成这样
$food = simplexml_load_string($food_feed);
//print_r($food);
if ($food->total_results != "0") {
foreach( $food->{'food'} as $food_entry ) {
echo $food_entry->food_id. "<br />\n";
echo $food_entry->food_name. "<br />\n";
echo $food_entry->food_description. "<br />\n";
echo "<br />\n";
}
}
else { //do some thing else
}
我正在尝试通过 food_id 和 food_name 从 Fatsecret REST API 返回的数组中创建一个下拉列表,但没有成功。
我的密码是
<?php
$base = rawurlencode("GET")."&";
$base .= "http%3A%2F%2Fplatform.fatsecret.com%2Frest%2Fserver.api&";
$params = "format=json&";
$params = "method=foods.search&";
$params .= "oauth_consumer_key=my key&";
$params .= "oauth_nonce=123&";
$params .= "oauth_signature_method=HMAC-SHA1&";
$params .= "oauth_timestamp=".time()."&";
$params .= "oauth_version=1.0&";
$params .= "search_expression=flour";
$params2 = rawurlencode($params);
$base .= $params2;
//encrypt it!
$sig= base64_encode(hash_hmac('sha1', $base, "4e0b6b00578b4a8995975b289879ae4e&", true));
$url = "http://platform.fatsecret.com/rest/server.api?".$params."&oauth_signature=".rawurlencode($sig);
返回的数组对象为
object(SimpleXMLElement)#555 (4) {
["max_results"]=> string(2) "20"
["total_results"]=> string(3) "186"
["page_number"]=> string(1) "0"
["food"]=> array(20) {
[0]=> object(SimpleXMLElement)#549 (5) {
["food_id"]=> string(4) "3419"
["food_name"]=> string(11) "White Flour"
["food_type"]=> string(7) "Generic"
["food_url"]=> string(63) "http://www.fatsecret.com/calories-nutrition/generic/flour-white"
["food_description"]=> string(75) "Per 100g - Calories: 364kcal | Fat: 0.98g | Carbs: 76.31g | Protein: 10.33g" }
[1]=> object(SimpleXMLElement)#554 (6) {
["food_id"]=> string(7) "1727595"
["food_name"]=> string(17) "All-Purpose Flour"
["brand_name"]=> string(10) "Gold Medal"
["food_type"]=> string(5) "Brand"
["food_url"]=> string(72) "http://www.fatsecret.com/calories-nutrition/gold-medal/all-purpose-flour"
["food_description"]=> string(77) "Per 1/4 cup - Calories: 100kcal | Fat: 0.00g | Carbs: 22.00g | Protein: 3.00g" }
[2]=> object(SimpleXMLElement)#553 (6) {
["food_id"]=> string(5) "56342"
["food_name"]=> string(17) "All Purpose Flour"
["brand_name"]=> string(7) "Wegmans"
["food_type"]=> string(5) "Brand"
["food_url"]=> string(69) "http://www.fatsecret.com/calories-nutrition/wegmans/all-purpose-flour"
["food_description"]=> string(78) "Per 1/4 cup - Calories: 100kcal | Fat: 0.00g | Carbs: 22.00g | Protein: 4.00g" }
此时我尝试了下面的代码
echo '<select>';
$jsonData = file_get_contents($url);
$jsonDataObject = json_decode($jsonData);
foreach($jsonDataObject->response->values as $option){
echo '<option value=' . $option->food_id . '>' . $option->food_name . '</option>';
}
echo '</select>';
但运气不好。
最终我尝试了
$food_feed = file_get_contents($url);
$food = simplexml_load_string($food_feed);
$obj_xml = simplexml_load_string($food_feed);
// Total number of elements present ///
$total = $obj_xml->count(); // total number of elements for PHP 5.3 and above
$str="<select name='student'>";
for($i=0; $i<$total; $i++) {
$str= $str . "<option value=".$obj_xml->food[$i]->food_id.">".$obj_xml->food[$i]->food_name. "</option>";
}
$str = $str. "</select>";
echo $str;
这段代码确实有效但是它在下拉列表的末尾添加了几个额外的空行,我找不到原因。
如果有人能帮助我找到实现目标的更好方法,我将不胜感激。
此致
好的,我已经设法解决了这个问题,以防万一这对某人有帮助。
$food 是一个 simplexml 对象,我们可以访问像
这样的元素foreach( $food->{'[array]'} as $array_variable )
所以我们的循环会变成这样
$food = simplexml_load_string($food_feed);
//print_r($food);
if ($food->total_results != "0") {
foreach( $food->{'food'} as $food_entry ) {
echo $food_entry->food_id. "<br />\n";
echo $food_entry->food_name. "<br />\n";
echo $food_entry->food_description. "<br />\n";
echo "<br />\n";
}
}
else { //do some thing else
}