如何解决使用 PHP 调用 JSON 文件但无法以我想要的方式回显
我想通过一个非常简单的 php 文件跟踪我感兴趣的股票的价格。为此,我试图从 jsonld 文件中调用某些数据,但无法这样做。那主要是因为我无法设置正确的顺序。 这是我的php代码:
<?
// Get the contents of the JSON file
$strJsonFileContents = file_get_contents("data.jsonld");
$datas = json_decode($strJsonFileContents,True);
//var_dump($datas); // print array
$dataname = $datas->currency[ALGYO];
$dataprice = $datas->currency[ALGYO]->price;
echo $data;
?>
我调用了文件,可以用 var_dump 回显。
可以看到Json文件here
我想要做的是调用货币 ALGYO 及其价格,然后在另一个表或行中调用 ACSEL 及其价格等等。我只会调用某些特定元素,因此所有元素的列表并不是我要找的。有人可以给我指路吗?提前致谢。
对于那些不想关注 pastebin 链接的人,我也在下面留下了一个可读版本的 json。
{"@context": "http://schema.org","@type": "WebPage","name": "BORSA","mainEntity": {
"@type": "ItemList","itemListElement": [
{
"@type": "ExchangeRateSpecification","currency": "ALGYO","currentExchangeRate": {
"@type": "UnitPriceSpecification","price": 26.14,"priceCurrency": "TRY"
}
},{
"@type": "ExchangeRateSpecification","currency": "ARZUM","price": 24.74,"currency": "ACSEL","price": 22.9,"currency": "ADANA","price": 12.19,"currency": "ADBGR","price": 8.62,"currency": "PAMEL","price": 22.02,"priceCurrency": "TRY"
}
}
]
}
}
解决方法
虽然你说你不想要所有元素的列表不是我想要的,但如果你想按照自己的顺序挑选特定的元素可能会更容易。
这只是提取 currentExchangeRate 子数组并按货币对其进行索引...
$rates = array_column($datas['mainEntity']["itemListElement"],"currentExchangeRate","currency");
echo "ALGYO rate=" . $rates['ALGYO']['price'];
print_r($rates);
给...
ALGYO rate=26.14
Array
(
[ALGYO] => Array
(
[@type] => UnitPriceSpecification
[price] => 26.14
[priceCurrency] => TRY
)
[ARZUM] => Array
(
[@type] => UnitPriceSpecification
[price] => 24.74
[priceCurrency] => TRY
)
[ACSEL] => Array
(
[@type] => UnitPriceSpecification
[price] => 22.9
[priceCurrency] => TRY
)
[ADANA] => Array
(
[@type] => UnitPriceSpecification
[price] => 12.19
[priceCurrency] => TRY
)
[ADBGR] => Array
(
[@type] => UnitPriceSpecification
[price] => 8.62
[priceCurrency] => TRY
)
[PAMEL] => Array
(
[@type] => UnitPriceSpecification
[price] => 22.02
[priceCurrency] => TRY
)
)
,
您可以使用一个函数,该函数允许您从 json 中获取“项目”(库存)特定数据。
您可以(应该)定制函数以满足您的需求,这是一个搜索商品并返回其价格的示例:
$json = file_get_contents('data.json');
$arr = json_decode($json,true);
getItem($arr,'ALGYO'); // item : ALGYO price: 26.14
getItem($arr,'ACSEL'); // item : ACSEL price: 22.9
function getItem($arr,$item)
{
$records = $arr['mainEntity']['itemListElement']; // the records
foreach ($records as $record) {
if ($record['currency'] == $item) {
echo 'item : ' . $item;
echo '<br />';
echo 'price : ' . $record['currentExchangeRate']['price'];
echo '<br />';
}
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。