>我有一个文本文件,其中包含以分号分隔的项目列表。我想让每个分号创建一个新的 HTML tr。此外,我希望分号分隔的项目内的逗号将项目分成列 (td(。该表将有三列。
如何用 php 做到这一点?
一种方法是:
$input = "1,2,3;4,5,6;7,8,9";
echo "<table>'n<tr><td>".str_replace(array(",", ";"), array("</td><td>", "</td></tr>'n<tr><td>"), $input)."</td></tr></table>";
结果:
<table>
<tr><td>1</td><td>2</td><td>3</td></tr>
<tr><td>4</td><td>5</td><td>6</td></tr>
<tr><td>7</td><td>8</td><td>9</td></tr></table>
标准方法
首先拆分字符串...假设您有:
$str = 'text, something, value; another, extra, thing; string, content, data';
注意:您可以使用 file_get_contents
读取文件。
现在您可以使用爆炸来获取零件:
$rows = explode(';', $str);
foreach ($rows as $row)
{
$cells = explode(',', $row);
//....
}
并输出:
$rows = explode(';', $str);
foreach ($rows as $row)
{
echo '<tr>';
$cells = explode(',', $row);
foreach ($cells as $cell)
{
echo '<td>'.$cell.'</td>'
}
echo '</tr>';
echo "'n"; // just for presentation
}
这将产生:
<tr><td>text</td><td>something</td><td>value</td></tr>
<tr><td>another</td><td>extra<td><td>thing</td></tr>
<tr><td>string</td><td>content<td><td>data</td></tr>
str_getcsv
从 PHP 5.3 及更高版本开始,您可以使用str_getcsv:
$rows = str_getcsv($str, ';');
foreach ($rows as $row)
{
echo '<tr>';
$cells = str_getcsv(',', $row);
foreach ($cells as $cell)
{
echo '<td>'.$cell.'</td>'
}
echo '</tr>';
echo "'n"; // just for presentation
}
使用 str_getcsv
的早期之处在于它允许您指定eclosure
和escape
字符。例如:
$str = '"text", "something", "value"; "another", "look: '"escape sequence'"";
在那里enclosure
字符是"
,escape
字符是'
.
$data = file("your_file.txt");
foreach ($data as $line) {
$trs = explode(";", $line);
foreach ($trs as $tr) {
echo '<tr>';
$tds = explode(",", $tr);
foreach ($tds as $td) {
echo '<td>';
echo $td;
echo '</td>';
}
echo '</tr>';
}
}
使用 explode
函数 (http://www.php.net/explode(,然后循环访问结果并将其回显到表中。
使用 explode()
.
$fn = fopen("test.txt","r") or die("fail to open file");
while($row = fgets($fn)) {
$content = explode( ";", $row);
echo '<tr>' . $content . '<tr />';
}
fclose( $fn );
您可以使用
file_get_contents,爆炸和内爆来非常轻松地执行此操作:
$data = file_get_contents('file.txt');
$semi = explode(";", $data);
foreach($semi AS $row)
{
$td = explode(",", $row);
echo '<tr><td>' . implode('</td><td>', $td) . '</td></tr>';
}