2011-01-20 179 views
22

如何從PHP數組創建HTML表格?標題爲'標題','價格''號'的表格。如何從PHP數組創建HTML表?

$shop = array(
    array("rose", 1.25, 15), 
    array("daisy", 0.75, 25), 
    array("orchid", 1.15, 7), 
); 
+3

這是完全相同的問題http://stackoverflow.com/questions/4746079/how-do-i-create-table-with-this-php-array請不要雙重發布問題 - 你只是浪費你自己(和其他人)的時間。 – 2011-01-20 18:15:58

+3

合併。並且,祈禱我不再合併! – Will 2011-01-20 18:40:01

+0

此線程已在這裏回答[點擊此處](https://stackoverflow.com/questions/4746079/how-to-create-a-html-table-from-a-php-array/47068295#47068295) – Delickate 2017-11-02 06:08:56

回答

2

構建兩個foreach循環並迭代你的數組。 打印出該值並在其周圍添加HTML表格標籤。

10
<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> 
+5

什麼是模板標籤的問題? @HalfCrazed – 2014-10-06 07:24:53

+1

短標籤不適用於所有系統 – DarkMukke 2015-07-31 14:39:36

0
<?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>'; 

您可以優化它,但應該做的。

58

這將是最好只把數據放到數組是這樣的:

<?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; ?> 
2
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>'; 
0

您可以使用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>'; 
1
<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> 
4
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>"; 
0

這裏我的答案。

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); 

希望它幫助;)

26

這裏是我的:

<?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); 
?> 
1

您可以使用此功能。

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; 
} 
-1
<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> 
3

您也可以還使用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>"; 
1

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;`` 
} 
0

數組表。 數組轉換爲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幫助您。