如何從PHP數組創建HTML表格?標題爲'標題','價格'和'號'的表格。如何從PHP數組創建HTML表?
$shop = array(
array("rose", 1.25, 15),
array("daisy", 0.75, 25),
array("orchid", 1.15, 7),
);
如何從PHP數組創建HTML表格?標題爲'標題','價格'和'號'的表格。如何從PHP數組創建HTML表?
$shop = array(
array("rose", 1.25, 15),
array("daisy", 0.75, 25),
array("orchid", 1.15, 7),
);
構建兩個foreach循環並迭代你的數組。 打印出該值並在其周圍添加HTML表格標籤。
<table>
<tr>
<td>title</td>
<td>price</td>
<td>number</td>
</tr>
<? foreach ($shop as $row) : ?>
<tr>
<td><? echo $row[0]; ?></td>
<td><? echo $row[1]; ?></td>
<td><? echo $row[2]; ?></td>
</tr>
<? endforeach; ?>
</table>
什麼是模板標籤的問題? @HalfCrazed – 2014-10-06 07:24:53
短標籤不適用於所有系統 – DarkMukke 2015-07-31 14:39:36
<?php
echo "<table>
<tr>
<th>title</th>
<th>price</th>
<th>number</th>
</tr>";
for ($i=0; $i<count($shop, 0); $i++)
{
echo '<tr>';
for ($j=0; $j<3; $j++)
{
echo '<td>'.$shop[$i][$j].'</td>';
}
echo '</tr>';
}
echo '</table>';
您可以優化它,但應該做的。
這將是最好只把數據放到數組是這樣的:
<?php
$shop = array(array("title"=>"rose", "price"=>1.25 , "number"=>15),
array("title"=>"daisy", "price"=>0.75 , "number"=>25),
array("title"=>"orchid", "price"=>1.15 , "number"=>7)
);
?>
然後做這樣的事情,這應該很好地工作,甚至當你在數據庫中添加更多的列到你的桌子後面。
<?php if (count($shop) > 0): ?>
<table>
<thead>
<tr>
<th><?php echo implode('</th><th>', array_keys(current($shop))); ?></th>
</tr>
</thead>
<tbody>
<?php foreach ($shop as $row): array_map('htmlentities', $row); ?>
<tr>
<td><?php echo implode('</td><td>', $row); ?></td>
</tr>
<?php endforeach; ?>
</tbody>
</table>
<?php endif; ?>
echo '<table><tr><th>Title</th><th>Price</th><th>Number</th></tr>';
foreach($shop as $id => $item) {
echo '<tr><td>'.$item[0].'</td><td>'.$item[1].'</td><td>'.$item[2].'</td></tr>';
}
echo '</table>';
您可以使用foreach
遍歷數組$shop
,並得到一個陣列,每個迭代呼應這樣的價值觀:
echo '<table>';
echo '<tr><th>title</td><td>price</td><td>number</td></tr>';
foreach ($shop as $item) {
echo '<tr>';
echo '<td>'.$item[0].'</td>';
echo '<td>'.$item[1].'</td>';
echo '<td>'.$item[2].'</td>';
ehoc '</tr>';
}
echo '</table>';
<table>
<thead>
<tr><th>title</th><th>price><th>number</th></tr>
</thead>
<tbody>
<?php
foreach ($shop as $row) {
echo '<tr>';
foreach ($row as $item) {
echo "<td>{$item}</td>";
}
echo '</tr>';
}
?>
</tbody>
</table>
echo "<table><tr><th>Title</th><th>Price</th><th>Number</th></tr>";
foreach($shop as $v){
echo "<tr>";
foreach($v as $vv){
echo "<td>{$vv}</td>";
}
echo "<tr>";
}
echo "</table>";
這裏我的答案。
function array2Html($array, $table = true)
{
$out = '';
foreach ($array as $key => $value) {
if (is_array($value)) {
if (!isset($tableHeader)) {
$tableHeader =
'<th>' .
implode('</th><th>', array_keys($value)) .
'</th>';
}
array_keys($value);
$out .= '<tr>';
$out .= array2Html($value, false);
$out .= '</tr>';
} else {
$out .= "<td>$value</td>";
}
}
if ($table) {
return '<table>' . $tableHeader . $out . '</table>';
} else {
return $out;
}
}
但是,您的表頭必須是數組的一部分,當它來自數據庫時這很常見。例如
$shop = array(
array(
'title' => 'rose',
'price' => 1.25,
'number' => 15,
),
array(
'title' => 'daisy',
'price' => 0.75,
'number' => 25,
),
array(
'title' => 'orchid',
'price' => 1.15,
'number' => 7,
),
);
print arrayToHtml($shop);
希望它幫助;)
這裏是我的:
<?php
function build_table($array){
// start table
$html = '<table>';
// header row
$html .= '<tr>';
foreach($array[0] as $key=>$value){
$html .= '<th>' . htmlspecialchars($key) . '</th>';
}
$html .= '</tr>';
// data rows
foreach($array as $key=>$value){
$html .= '<tr>';
foreach($value as $key2=>$value2){
$html .= '<td>' . htmlspecialchars($value2) . '</td>';
}
$html .= '</tr>';
}
// finish table and return it
$html .= '</table>';
return $html;
}
$array = array(
array('first'=>'tom', 'last'=>'smith', 'email'=>'[email protected]', 'company'=>'example ltd'),
array('first'=>'hugh', 'last'=>'blogs', 'email'=>'[email protected]', 'company'=>'example ltd'),
array('first'=>'steph', 'last'=>'brown', 'email'=>'[email protected]', 'company'=>'example ltd')
);
echo build_table($array);
?>
您可以使用此功能。
function insertTable($myTableArrayBody) {
$x = 0;
$y = 0;
$seTableStr = '<table><tbody>';
while (isset($myTableArrayBody[$y][$x])) {
$seTableStr .= '<tr>';
while (isset($myTableArrayBody[$y][$x])) {
$seTableStr .= '<td>' . $myTableArrayBody[$y][$x] . '</td>';
$x++;
}
$seTableStr .= '</tr>';
$x = 0;
$y++;
}
$seTableStr .= '</tbody></table>';
return $seTableStr;
}
<table id="usuarios">
<tbody>
<tr>
<th>Nombre</th>
<th>Apellido</th>
<th>Email</th>
<th>Institución educativa</th>
<th>Fecha Registro</th>
</tr>
<?php
if ($result->num_rows > 0) {// output data of each row
while($row = $result->fetch_assoc()) {
echo "<tr><td>".$row["Nombre"]."</td>";
echo "<td>".$row["Apellido"]."</td>";
echo "<td>".$row["Email"]."</td>";
echo "<td>".$row["NombreInsEdu"]."</td>";
echo "<td>".$row["FechaRegistro"]."</td></tr>";
}
} else {
echo "0 results";
}
$conn->close();
?>
</tbody>
</table>
您也可以還使用array_reduce
例如:
在身體的前面加上表頭,您可以設置第二個參數$myTableArrayHeader
和做相同的報頭信息
$tbody = array_reduce($rows, function($a, $b){return $a.="<tr><td>".implode("</td><td>",$b)."</td></tr>";});
$thead = "<tr><th>" . implode("</th><th>", array_keys($rows[0])) . "</th></tr>";
echo "<table>\n$thead\n$tbody\n</table>";
PHP代碼:
$multiarray = array (
array("name"=>"Argishti", "surname"=>"Yeghiazaryan"),
array("name"=>"Armen", "surname"=>"Mkhitaryan"),
array("name"=>"Arshak", "surname"=>"Aghabekyan"),
);
$count = 0;
foreach ($multiarray as $arrays){
$count++;
echo "<table>" ;
echo "<span>table $count</span>";
echo "<tr>";
foreach ($arrays as $names => $surnames){
echo "<th>$names</th>";
echo "<td>$surnames</td>";
}
echo "</tr>";
echo "</table>";
}
CSS:
table {
font-family: arial, sans-serif;
border-collapse: collapse;
width: 100%;
}
td, th {
border: 1px solid #dddddd;
text-align: left;
padding: 8px;``
}
數組表。 數組轉換爲div。 JSON到表中。 將JSON轉換爲div。
所有的都很好地處理這個類。 Click here to get a class
如何使用它?
剛剛獲得和對象
$obj = new Arrayinto();
創建要轉換
$obj->array_object = array("AAA" => "1111",
"BBB" => "2222",
"CCC" => array("CCC-1" => "123",
"CCC-2" => array("CCC-2222-A" => "CA2",
"CCC-2222=B" => "CB2"
)
)
);
如果你想數組轉換爲表數組。調用這個。
$result = $obj->process_table();
如果您想將數組轉換爲div。調用這個。
$result = $obj->process_div();
我們假設,如果你有一個JSON
$obj->json_string = '{
"AAA":"11111",
"BBB":"22222",
"CCC":[
{
"CCC-1":"123"
},
{
"CCC-2":"456"
}
]
}
';
可以轉換成表格/ DIV這樣
$result = $obj->process_json('div');
OR
$result = $obj->process_json('table');
希望this'd幫助您。
這是完全相同的問題http://stackoverflow.com/questions/4746079/how-do-i-create-table-with-this-php-array請不要雙重發布問題 - 你只是浪費你自己(和其他人)的時間。 – 2011-01-20 18:15:58
合併。並且,祈禱我不再合併! – Will 2011-01-20 18:40:01
此線程已在這裏回答[點擊此處](https://stackoverflow.com/questions/4746079/how-to-create-a-html-table-from-a-php-array/47068295#47068295) – Delickate 2017-11-02 06:08:56