给定一个包含 json 格式数据的 API,我如何以 HTML table 格式显示数据?
Given an API with data in json format, how do i present the data in a HTML table?
到目前为止,我有这个 PHP cURL 代码:
<?php
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => "https://play.dhis2.org/release1/api/25/analytics.json?dimension=dx%3AYtbsuPPo010%3Bl6byfWFUGaP%3Bs46m5MS0hxu&dimension=pe%3ALAST_12_MONTHS&filter=ou%3AImspTQPwCqd&displayProperty=NAME&skipMeta=true",
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "GET",
CURLOPT_HTTPHEADER => array(
"authorization: Basic YWRtaW46ZGlzdHJpY3Q=",
"cache-control: no-cache",
"postman-token: c7fc6164-194a-24ea-ccea-9f6bdbcd66f5"
),
));
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
echo "cURL Error #:" . $err;
} else {
echo $response;
}
到目前为止,我已经尝试过(未成功):
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
echo "cURL Error #:" . $err;
} else {
$data = json_decode($response, true);
$immunization = $data["rows"];
foreach ($immunizations as $immunization) {
echo '<tr>';
echo '<td>' . $immunization['name'] . '</td>';
echo '<td>' . $immunization['date'] . '</td>';
echo '<td>' . $immunization['type'] . '</td>';
echo '</tr>';
}
}
有人帮我遍历 JSON 并将数据按行放在我的 table 上。
在postman上,使用Basic Auth,用户名:admin,密码:district
提前致谢!
首先,你有
$immunization = $data["rows"];
foreach ($immunizations as $immunization) {
您应该将首字母 $immunization
复数化为 $immunizations
才能正常工作。所以你得到
$immunizations = $data["rows"];
foreach ($immunizations as $immunization) {
其次,查看您返回的数据,它们没有 name, date, type
键。他们就是那样的价值观。所以将循环更新为
foreach ($immunizations as $immunization) {
echo '<tr>';
echo '<td>' . $immunization[0] . '</td>';
echo '<td>' . $immunization[1] . '</td>';
echo '<td>' . $immunization[2] . '</td>';
echo '</tr>';
}
到目前为止,我有这个 PHP cURL 代码:
<?php
$curl = curl_init();
curl_setopt_array($curl, array(
CURLOPT_URL => "https://play.dhis2.org/release1/api/25/analytics.json?dimension=dx%3AYtbsuPPo010%3Bl6byfWFUGaP%3Bs46m5MS0hxu&dimension=pe%3ALAST_12_MONTHS&filter=ou%3AImspTQPwCqd&displayProperty=NAME&skipMeta=true",
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "GET",
CURLOPT_HTTPHEADER => array(
"authorization: Basic YWRtaW46ZGlzdHJpY3Q=",
"cache-control: no-cache",
"postman-token: c7fc6164-194a-24ea-ccea-9f6bdbcd66f5"
),
));
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
echo "cURL Error #:" . $err;
} else {
echo $response;
}
到目前为止,我已经尝试过(未成功):
$response = curl_exec($curl);
$err = curl_error($curl);
curl_close($curl);
if ($err) {
echo "cURL Error #:" . $err;
} else {
$data = json_decode($response, true);
$immunization = $data["rows"];
foreach ($immunizations as $immunization) {
echo '<tr>';
echo '<td>' . $immunization['name'] . '</td>';
echo '<td>' . $immunization['date'] . '</td>';
echo '<td>' . $immunization['type'] . '</td>';
echo '</tr>';
}
}
有人帮我遍历 JSON 并将数据按行放在我的 table 上。
在postman上,使用Basic Auth,用户名:admin,密码:district 提前致谢!
首先,你有
$immunization = $data["rows"];
foreach ($immunizations as $immunization) {
您应该将首字母 $immunization
复数化为 $immunizations
才能正常工作。所以你得到
$immunizations = $data["rows"];
foreach ($immunizations as $immunization) {
其次,查看您返回的数据,它们没有 name, date, type
键。他们就是那样的价值观。所以将循环更新为
foreach ($immunizations as $immunization) {
echo '<tr>';
echo '<td>' . $immunization[0] . '</td>';
echo '<td>' . $immunization[1] . '</td>';
echo '<td>' . $immunization[2] . '</td>';
echo '</tr>';
}