1

所以我几乎得到了我想要的输出,除了一件事。我似乎无法弄清楚如何使用 PHP 在 HTML 表内的新行上打印我的 XML 文件的特定部分来回显它。

在 PHP 方面我不是最伟大的,但我觉得涉猎很有趣。至于我到目前为止的代码,我将发布我的 PHP 部分。

<?php
$file="badscifimovies.xml";
$xml = simplexml_load_file($file) or die ("no load");
echo <<<EOF
<table>
  <tr>
    <th>Title</th>
    <th>Year</th>
    <th>Producers/Director</th>
    <th>Stars</th>
    <th>Budget</th>
    <th>MST3000</th>
  </tr>
EOF;
foreach($xml->movie as $movie){
  echo "<tr>";
  echo "<td>{$movie->title}</td>";
  echo "<td>{$movie->year}</td>";
  echo "<td>{$movie->director->producer}</td>";
  foreach($movie->stars->star as $stars){
    echo "<td>{$stars[0]}</td>";
  }
  echo "<td>{$movie->budget}</td>";
  echo "<td>{$movie->mst}</td>";
  echo "<br />";
  echo "</tr>";
}
echo '</table>';
?>

我正在寻找的输出是“星星”部分。我得到的 XML 部分是这样的:

<stars>
  <star>Name One</star>
  <star>Name two</star>
  <star>Name three</star>
</star>

我似乎无法在单独的行上打印每一个。我的所有其他代码都可以很好地打印出 XML 文档的其余部分(可能是因为每部电影有 1 个元素)。对于星星部分,它会并排打印所有三颗星星,但会将我的每个电影部分打印在一个新的行上,就像它应该的那样。

任何帮助,将不胜感激。如果您需要我提供更多信息,我会发布更多信息。

4

3 回答 3

2

XML 文件 (employee.xml)

<root>
<person>
    <sno>1</sno>
    <name>person1</name>
    <phno>098687667</phno>
</person>
<person>
    <sno>2</sno>
    <name>person2</name>
    <phno>897876756</phno>
</person>
<person>
    <sno>3</sno>
    <name>person3</name>
    <phno>986875675</phno>
</person>

PHP 代码

<body>
<?php
$xml = simplexml_load_file("employee.xml")
or die("Error: Cannot create object");

$element_name = array();                                    //get all xml element name
foreach ($xml->children()->children() as $value) {
$element_name[] = $value->getName();
}
?>
<table border = "1">
<thead>
<tr>
<?php
foreach ($element_name as $value) {             //display table head
echo "<th>{$value}</th>";
}
?>
</tr>
</thead>

<tbody>
<?php
foreach ($xml->children() as $value) {              //display table data
echo "<tr>";    
for ($i = 0; $i < count($element_name); $i++) {
echo "<td>{$value->children()->$element_name[$i]}</td>";
}
echo "</tr>";
}
?>
</tbody>
</table>
</body>
于 2014-12-30T10:48:00.787 回答
1
foreach($xml->movie as $movie){
  echo "<tr>";
  echo "<td>{$movie->title}</td>";
  echo "<td>{$movie->year}</td>";
  echo "<td>{$movie->director->producer}</td>";
  echo "<td>";
  foreach($movie->stars->star as $stars){
    echo $stars[0] . '<br/>';
  }
  echo "</td>";
  echo "<td>{$movie->budget}</td>";
  echo "<td>{$movie->mst}</td>";
  echo "<br />";
  echo "</tr>";
}

我认为这应该有效。您正在为每颗星创建一个新<td>元素,但您只有一个<th>对应的标签。

于 2013-10-11T07:48:03.430 回答
0

动态转换:

http://mdb-blog.blogspot.com/2015/11/php-xml-to-html-table-elment-convertion.html

对于任何 xml...

于 2015-12-29T13:42:15.570 回答